@sendbird/uikit-react
Version:
Sendbird UIKit for React: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.
145 lines (138 loc) • 8.5 kB
JavaScript
;
Object.defineProperty(exports, '__esModule', { value: true });
var _tslib = require('../../chunks/bundle-jAsAzWpU.js');
var React = require('react');
var MutedMemberList = require('../../chunks/bundle-SlJSIlpP.js');
var MemberList = require('../../chunks/bundle-CIn5419q.js');
var LocalizationContext = require('../../chunks/bundle-ClT0IexP.js');
var ui_Icon = require('../../ui/Icon.js');
var ui_Badge = require('../../ui/Badge.js');
var ui_Toggle = require('../../ui/Toggle.js');
var ui_Label = require('../../chunks/bundle-DxZzcGya.js');
var ChannelSettings_components_ChannelSettingsMenuItem = require('../components/ChannelSettingsMenuItem.js');
var useChannelSettings = require('../../chunks/bundle-_yh4eC6v.js');
require('../../chunks/bundle-CofqAAwu.js');
require('@sendbird/chat');
require('@sendbird/chat/openChannel');
require('../../chunks/bundle-on0zTbLT.js');
require('../../chunks/bundle-Buar9ys-.js');
require('../../chunks/bundle-DZN-28o5.js');
require('@sendbird/chat/groupChannel');
require('../../chunks/bundle-BTzm82Jl.js');
require('react-dom');
require('../../chunks/bundle-1F9guuKw.js');
require('../../ui/SortByRow.js');
require('../../chunks/bundle-BNgfU9I_.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/Button.js');
require('../../ui/UserListItem.js');
require('../../chunks/bundle-iF1pW7_s.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');
require('../../chunks/bundle-D-_6Kk3L.js');
require('../../chunks/bundle-BXuNw6bR.js');
require('../../chunks/bundle-BSCZWP_l.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 commonIconProps = {
fillColor: ui_Icon.IconColors.PRIMARY,
width: 24,
height: 24,
className: 'sendbird-channel-settings__accordion-icon',
};
var commonLabelProps = {
type: ui_Label.LabelTypography.SUBTITLE_1,
color: ui_Label.LabelColors.ONBACKGROUND_1,
};
var useMenuItems = function () {
var _a = React.useState(false), frozen = _a[0], setFrozen = _a[1];
var stringSet = React.useContext(LocalizationContext.LocalizationContext).stringSet;
var _b = useChannelSettings.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"
React.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 React.useMemo(function () { return ({
operator: {
operators: {
icon: _tslib.__assign(_tslib.__assign({}, commonIconProps), { type: ui_Icon.IconTypes.OPERATOR }),
label: _tslib.__assign(_tslib.__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__OPERATORS__TITLE }),
accordionComponent: function () { return React__default.default.createElement(MutedMemberList.OperatorList, { renderUserListItem: renderUserListItem }); },
},
allUsers: {
icon: _tslib.__assign(_tslib.__assign({}, commonIconProps), { type: ui_Icon.IconTypes.MEMBERS }),
label: _tslib.__assign(_tslib.__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__MEMBERS__TITLE }),
rightComponent: function (props) { return (React__default.default.createElement("div", { className: "sendbird-channel-settings__members" },
React__default.default.createElement(ui_Badge, { count: (channel === null || channel === void 0 ? void 0 : channel.memberCount) ? kFormatter(channel.memberCount) : '' }),
React__default.default.createElement(ChannelSettings_components_ChannelSettingsMenuItem.MenuItemAction, _tslib.__assign({}, props)))); },
accordionComponent: function () { return React__default.default.createElement(MemberList.MemberList, { renderUserListItem: renderUserListItem }); },
},
mutedUsers: {
icon: _tslib.__assign(_tslib.__assign({}, commonIconProps), { type: ui_Icon.IconTypes.MUTE }),
label: _tslib.__assign(_tslib.__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__MUTED_MEMBERS__TITLE }),
accordionComponent: function () { return React__default.default.createElement(MutedMemberList.MutedMemberList, { renderUserListItem: renderUserListItem }); },
},
bannedUsers: {
icon: _tslib.__assign(_tslib.__assign({}, commonIconProps), { type: ui_Icon.IconTypes.BAN }),
label: _tslib.__assign(_tslib.__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__BANNED_MEMBERS__TITLE }),
accordionComponent: function () { return React__default.default.createElement(MutedMemberList.BannedUserList, { renderUserListItem: renderUserListItem }); },
},
freezeChannel: {
hideMenu: channel === null || channel === void 0 ? void 0 : channel.isBroadcast,
icon: _tslib.__assign(_tslib.__assign({}, commonIconProps), { type: ui_Icon.IconTypes.FREEZE }),
label: _tslib.__assign(_tslib.__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__FREEZE_CHANNEL }),
rightComponent: function () { return 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; });
});
}
} }); },
},
},
nonOperator: {
allUsers: {
icon: _tslib.__assign(_tslib.__assign({}, commonIconProps), { type: ui_Icon.IconTypes.MEMBERS }),
label: _tslib.__assign(_tslib.__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__MEMBERS__TITLE }),
rightComponent: function (props) { return (React__default.default.createElement("div", { className: "sendbird-channel-settings__members" },
React__default.default.createElement(ui_Badge, { count: (channel === null || channel === void 0 ? void 0 : channel.memberCount) ? kFormatter(channel.memberCount) : '' }),
React__default.default.createElement(ChannelSettings_components_ChannelSettingsMenuItem.MenuItemAction, _tslib.__assign({}, props)))); },
accordionComponent: function () { return React__default.default.createElement(MemberList.MemberList, { renderUserListItem: renderUserListItem }); },
},
}
}); }, [channel === null || channel === void 0 ? void 0 : channel.url, frozen]);
};
exports.default = useMenuItems;
exports.useMenuItems = useMenuItems;
//# sourceMappingURL=useMenuList.js.map