@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
JavaScript
import { _ as __assign } from '../../chunks/bundle-DlZj_j5B.js';
import React__default, { useState, useContext, useEffect, useMemo } from 'react';
import { O as OperatorList, M as MutedMemberList, B as BannedUserList } from '../../chunks/bundle-DBk-n0aO.js';
import { M as MemberList } from '../../chunks/bundle-DVaAtiJX.js';
import { L as LocalizationContext } from '../../chunks/bundle-DxLnjDoJ.js';
import { IconColors, IconTypes } from '../../ui/Icon.js';
import Badge from '../../ui/Badge.js';
import { Toggle } from '../../ui/Toggle.js';
import { a as LabelTypography, b as LabelColors } from '../../chunks/bundle-FZ_FdxZT.js';
import { MenuItemAction } from '../components/ChannelSettingsMenuItem.js';
import { u as useChannelSettings } from '../../chunks/bundle-ab1EZFfD.js';
import '../../chunks/bundle-DsDOqEEW.js';
import '@sendbird/chat';
import '@sendbird/chat/openChannel';
import '../../chunks/bundle-BnaoVUUl.js';
import '../../chunks/bundle-C1jTnXNH.js';
import '../../chunks/bundle-C8kxBudB.js';
import '@sendbird/chat/groupChannel';
import '../../chunks/bundle-BRB1saAI.js';
import 'react-dom';
import '../../chunks/bundle-CaW4IP0_.js';
import '../../ui/SortByRow.js';
import '../../chunks/bundle-CSjCAZib.js';
import '../../ui/IconButton.js';
import '../../chunks/bundle-C5Cl3Igw.js';
import '../../utils/message/getOutgoingMessageState.js';
import '../../chunks/bundle-OJHU7Q3U.js';
import '../../chunks/bundle-DZaN4z9l.js';
import '../../chunks/bundle-0bJlK18Z.js';
import '../../ui/Button.js';
import '../../ui/UserListItem.js';
import '../../chunks/bundle-tDk7wyaM.js';
import '../../chunks/bundle-Dgt7lb2O.js';
import '../../ui/ImageRenderer.js';
import '../../chunks/bundle-h43SVTxb.js';
import '../../ui/MutedAvatarOverlay.js';
import '../../ui/Checkbox.js';
import '../../ui/UserProfile.js';
import '../../sendbirdSelectors.js';
import '../../chunks/bundle-D9lZlE3H.js';
import '../../chunks/bundle-BDItDVZl.js';
import '../../chunks/bundle-DWJPyrDa.js';
import '../../chunks/bundle-BPJmy9tK.js';
import '../../chunks/bundle-Zll3bhLI.js';
import '@sendbird/chat/message';
import '@sendbird/uikit-tools';
import '../../chunks/bundle-Cpv_LYki.js';
import '../../chunks/bundle-Dhutxl0X.js';
import '../../chunks/bundle-D89Qj0P4.js';
import '../../chunks/bundle-CQBvCw9O.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