UNPKG

@sendbird/uikit-react

Version:

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

115 lines (109 loc) 8.44 kB
'use strict'; var React = require('react'); var LocalizationContext = require('../../chunks/bundle-REYf6P50.js'); var ui_Accordion = require('../../ui/Accordion.js'); var ui_Label = require('../../chunks/bundle-D66YmzI6.js'); var ui_Icon = require('../../ui/Icon.js'); var ui_Badge = require('../../ui/Badge.js'); var ui_Toggle = require('../../ui/Toggle.js'); var MutedMemberList = require('../../chunks/bundle-BhbLo6cR.js'); var MemberList = require('../../chunks/bundle-CVQ76olT.js'); var useChannelSettings = require('../../chunks/bundle-79zaNhm6.js'); require('../../chunks/bundle-DdEJUQ3V.js'); require('../../chunks/bundle-BE-eUbjS.js'); require('../../chunks/bundle-C7WnFc5I.js'); require('../../ui/AccordionGroup.js'); require('../../chunks/bundle-kfqOElgK.js'); require('../../chunks/bundle-D6mmpicY.js'); require('../../chunks/bundle-HERYYUXZ.js'); require('../../chunks/bundle-DWBI0JnU.js'); require('@sendbird/chat'); require('@sendbird/chat/groupChannel'); require('@sendbird/chat/openChannel'); require('../../chunks/bundle-B46s7hdu.js'); require('../../chunks/bundle-BWLRRAFI.js'); require('react-dom'); require('../../ui/SortByRow.js'); require('../../chunks/bundle-BeuUz2c0.js'); require('../../ui/IconButton.js'); require('../../chunks/bundle-BUPw_lsA.js'); require('../../utils/message/getOutgoingMessageState.js'); require('../../chunks/bundle-DFNM8KjC.js'); require('../../chunks/bundle-CEY5QNl7.js'); require('../../chunks/bundle-BAy4Z2n_.js'); require('../../ui/Button.js'); require('../../ui/UserListItem.js'); require('../../chunks/bundle-H44hyvFN.js'); require('../../chunks/bundle-B4Oz6Uwy.js'); require('../../ui/ImageRenderer.js'); require('../../chunks/bundle-CHvo3SHq.js'); require('../../ui/MutedAvatarOverlay.js'); require('../../ui/Checkbox.js'); require('../../ui/UserProfile.js'); require('../../sendbirdSelectors.js'); require('../../chunks/bundle-CyJimqL9.js'); require('../../chunks/bundle-OV9QvRP8.js'); require('../../chunks/bundle-BmtTyZzB.js'); require('../../chunks/bundle-DY3OUu9y.js'); require('../../chunks/bundle-C9bb3iWF.js'); require('@sendbird/chat/message'); require('@sendbird/uikit-tools'); require('../../chunks/bundle-BdnzjZUX.js'); require('../../chunks/bundle-HkyQ0DjT.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; }; /** * @deprecated * `ModerationPanel` is deprecated. * Use `@sendbird/ChannelSettings/components/ChannelSettingMenuList` instead. */ function ModerationPanel() { var _a = React.useState(false), frozen = _a[0], setFrozen = _a[1]; var stringSet = React.useContext(LocalizationContext.LocalizationContext).stringSet; var channel = useChannelSettings.useChannelSettings().state.channel; // work around for // https://sendbird.slack.com/archives/G01290GCDCN/p1595922832000900 // SDK bug - after frozen/unfrozen myRole becomes "none" React.useEffect(function () { var _a; setFrozen((_a = channel === null || channel === void 0 ? void 0 : channel.isFrozen) !== null && _a !== void 0 ? _a : false); }, [channel]); return (React__default.default.createElement(ui_Accordion.AccordionGroup, { className: "sendbird-channel-settings__operator" }, React__default.default.createElement(ui_Accordion.default, { className: "sendbird-channel-settings__operators-list", id: "operators", renderTitle: function () { return (React__default.default.createElement(React__default.default.Fragment, null, React__default.default.createElement(ui_Icon.default, { type: ui_Icon.IconTypes.OPERATOR, fillColor: ui_Icon.IconColors.PRIMARY, width: 24, height: 24, className: "sendbird-channel-settings__accordion-icon" }), React__default.default.createElement(ui_Label.Label, { type: ui_Label.LabelTypography.SUBTITLE_1, color: ui_Label.LabelColors.ONBACKGROUND_1 }, stringSet.CHANNEL_SETTING__OPERATORS__TITLE))); }, renderContent: function () { return React__default.default.createElement(MutedMemberList.OperatorList, null); } }), React__default.default.createElement(ui_Accordion.default, { className: "sendbird-channel-settings__members-list", id: "members", renderTitle: function () { return (React__default.default.createElement(React__default.default.Fragment, null, React__default.default.createElement(ui_Icon.default, { type: ui_Icon.IconTypes.MEMBERS, fillColor: ui_Icon.IconColors.PRIMARY, width: 24, height: 24, className: "sendbird-channel-settings__accordion-icon" }), 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, { count: (channel === null || channel === void 0 ? void 0 : channel.memberCount) ? kFormatter(channel.memberCount) : '' }))); }, renderContent: function () { return React__default.default.createElement(MemberList.MemberList, null); } }), // No muted members in broadcast channel !(channel === null || channel === void 0 ? void 0 : channel.isBroadcast) && (React__default.default.createElement(ui_Accordion.default, { id: "mutedMembers", className: "sendbird-channel-settings__muted-members-list", renderTitle: function () { return (React__default.default.createElement(React__default.default.Fragment, null, React__default.default.createElement(ui_Icon.default, { type: ui_Icon.IconTypes.MUTE, fillColor: ui_Icon.IconColors.PRIMARY, width: 24, height: 24, className: "sendbird-channel-settings__accordion-icon" }), React__default.default.createElement(ui_Label.Label, { type: ui_Label.LabelTypography.SUBTITLE_1, color: ui_Label.LabelColors.ONBACKGROUND_1 }, stringSet.CHANNEL_SETTING__MUTED_MEMBERS__TITLE))); }, renderContent: function () { return React__default.default.createElement(MutedMemberList.MutedMemberList, null); } })), React__default.default.createElement(ui_Accordion.default, { className: "sendbird-channel-settings__banned-members-list", id: "bannedUsers", renderTitle: function () { return (React__default.default.createElement(React__default.default.Fragment, null, React__default.default.createElement(ui_Icon.default, { type: ui_Icon.IconTypes.BAN, fillColor: ui_Icon.IconColors.PRIMARY, width: 24, height: 24, className: "sendbird-channel-settings__accordion-icon" }), React__default.default.createElement(ui_Label.Label, { type: ui_Label.LabelTypography.SUBTITLE_1, color: ui_Label.LabelColors.ONBACKGROUND_1 }, stringSet.CHANNEL_SETTING__BANNED_MEMBERS__TITLE))); }, renderContent: function () { return React__default.default.createElement(MutedMemberList.BannedUserList, null); } }), // cannot freeze broadcast channel !(channel === null || channel === void 0 ? void 0 : channel.isBroadcast) && (React__default.default.createElement("div", { className: "sendbird-channel-settings__freeze" }, React__default.default.createElement(ui_Icon.default, { type: ui_Icon.IconTypes.FREEZE, fillColor: ui_Icon.IconColors.PRIMARY, width: 24, height: 24, className: "sendbird-channel-settings__accordion-icon" }), React__default.default.createElement(ui_Label.Label, { type: ui_Label.LabelTypography.SUBTITLE_1, color: ui_Label.LabelColors.ONBACKGROUND_1 }, stringSet.CHANNEL_SETTING__FREEZE_CHANNEL), React__default.default.createElement(ui_Toggle.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; }); }); } } }))))); } module.exports = ModerationPanel; //# sourceMappingURL=ModerationPanel.js.map