@sendbird/uikit-react
Version:
Sendbird UIKit for React: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.
109 lines (106 loc) • 6.63 kB
JavaScript
import { _ as __assign } from '../../chunks/bundle-DlZj_j5B.js';
import React__default, { useState } from 'react';
import { u as useChannelSettings } from '../../chunks/bundle-ab1EZFfD.js';
import { u as useLocalization } from '../../chunks/bundle-DxLnjDoJ.js';
import { useMenuItems } from '../hooks/useMenuList.js';
import { d as deleteNullish, c as classnames } from '../../chunks/bundle-CaW4IP0_.js';
import { ChannelSettingsHeader } from './ChannelSettingsHeader.js';
import PlaceHolder, { PlaceHolderTypes } from '../../ui/PlaceHolder.js';
import { L as Label, a as LabelTypography, b as LabelColors } from '../../chunks/bundle-FZ_FdxZT.js';
import Icon, { IconTypes, IconColors } from '../../ui/Icon.js';
import ChannelProfile from './ChannelProfile.js';
import LeaveChannel from './LeaveChannel.js';
import { MenuItem } from './ChannelSettingsMenuItem.js';
import { MenuListByRole } from './ChannelSettingMenuList.js';
import { u as useSendbird } from '../../chunks/bundle-BnaoVUUl.js';
export { B as BannedUserList, M as MutedMemberList, O as OperatorList } from '../../chunks/bundle-DBk-n0aO.js';
export { M as MemberList } from '../../chunks/bundle-DVaAtiJX.js';
import '../../chunks/bundle-C1jTnXNH.js';
import '../../chunks/bundle-C8kxBudB.js';
import '@sendbird/chat/groupChannel';
import '../../chunks/bundle-CSjCAZib.js';
import '../../chunks/bundle-CQBvCw9O.js';
import '../../chunks/bundle-tDk7wyaM.js';
import '../../chunks/bundle-Dhutxl0X.js';
import '../../chunks/bundle-D89Qj0P4.js';
import '../../ui/Badge.js';
import '../../ui/Toggle.js';
import '../../ui/Header.js';
import '../../chunks/bundle-DWJPyrDa.js';
import '../../ui/TextButton.js';
import '../../chunks/bundle-Bv6iXkjg.js';
import '../../ui/IconButton.js';
import '../../ui/Loader.js';
import '../../ui/ChannelAvatar.js';
import '../../chunks/bundle-Dgt7lb2O.js';
import '../../ui/ImageRenderer.js';
import '../../chunks/bundle-h43SVTxb.js';
import '../../chunks/bundle-DGOBflIQ.js';
import './EditDetailsModal.js';
import '../../chunks/bundle-BDItDVZl.js';
import 'react-dom';
import '../../ui/Button.js';
import '../../ui/Input.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 '../../chunks/bundle-Zll3bhLI.js';
import '@sendbird/chat/message';
import '@sendbird/chat';
import '@sendbird/chat/openChannel';
import '../../chunks/bundle-DsDOqEEW.js';
import '../../chunks/bundle-BRB1saAI.js';
import '../../ui/SortByRow.js';
import '../../ui/UserListItem.js';
import '../../ui/MutedAvatarOverlay.js';
import '../../ui/Checkbox.js';
import '../../ui/UserProfile.js';
import '../../sendbirdSelectors.js';
import '../../chunks/bundle-D9lZlE3H.js';
import '../../chunks/bundle-BPJmy9tK.js';
import '@sendbird/uikit-tools';
import '../../chunks/bundle-Cpv_LYki.js';
var ChannelSettingsUI = function (props) {
var _a = deleteNullish(props), _b = _a.renderHeader, renderHeader = _b === void 0 ? function (props) { return React__default.createElement(ChannelSettingsHeader, __assign({}, props)); } : _b, renderLeaveChannel = _a.renderLeaveChannel, renderChannelProfile = _a.renderChannelProfile, _c = _a.renderModerationPanel, renderModerationPanel = _c === void 0 ? function (props) { return React__default.createElement(MenuListByRole, __assign({}, props)); } : _c, renderPlaceholderError = _a.renderPlaceholderError, renderPlaceholderLoading = _a.renderPlaceholderLoading;
var state = useSendbird().state;
var isOnline = state.config.isOnline;
var _d = useChannelSettings().state, channel = _d.channel, invalidChannel = _d.invalidChannel, onCloseClick = _d.onCloseClick, loading = _d.loading;
var stringSet = useLocalization().stringSet;
var menuItems = useMenuItems();
var _e = useState(false), showLeaveChannelModal = _e[0], setShowLeaveChannelModal = _e[1];
if (loading) {
if (renderPlaceholderLoading)
return renderPlaceholderLoading();
return React__default.createElement(PlaceHolder, { type: PlaceHolderTypes.LOADING });
}
var headerProps = { onCloseClick: onCloseClick };
if (invalidChannel || !channel) {
return (React__default.createElement("div", null,
renderHeader(headerProps),
React__default.createElement("div", null, renderPlaceholderError ? renderPlaceholderError() : React__default.createElement(PlaceHolder, { type: PlaceHolderTypes.WRONG }))));
}
return (React__default.createElement(React__default.Fragment, null,
renderHeader(headerProps),
React__default.createElement("div", { className: "sendbird-channel-settings__scroll-area" },
(renderChannelProfile === null || renderChannelProfile === void 0 ? void 0 : renderChannelProfile()) || React__default.createElement(ChannelProfile, null), renderModerationPanel === null || renderModerationPanel === void 0 ? void 0 :
renderModerationPanel({ menuItems: menuItems }),
(renderLeaveChannel === null || renderLeaveChannel === void 0 ? void 0 : renderLeaveChannel()) || (React__default.createElement(MenuItem, { className: classnames(!isOnline ? 'sendbird-channel-settings__panel-item__disabled' : '', 'sendbird-channel-settings__panel-item__leave-channel'), onKeyDown: function () {
if (!isOnline)
return;
setShowLeaveChannelModal(true);
}, onClick: function () {
if (!isOnline)
return;
setShowLeaveChannelModal(true);
}, renderLeft: function () { return (React__default.createElement(Icon, { className: ['sendbird-channel-settings__panel-icon-left', 'sendbird-channel-settings__panel-icon__leave'].join(' '), type: IconTypes.LEAVE, fillColor: IconColors.ERROR, height: "24px", width: "24px" })); }, renderMiddle: function () { return (React__default.createElement(Label, { type: LabelTypography.SUBTITLE_1, color: LabelColors.ONBACKGROUND_1 }, stringSet.CHANNEL_SETTING__LEAVE_CHANNEL__TITLE)); } })),
showLeaveChannelModal && (React__default.createElement(LeaveChannel, { onCancel: function () {
setShowLeaveChannelModal(false);
}, onSubmit: function () {
setShowLeaveChannelModal(false);
onCloseClick === null || onCloseClick === void 0 ? void 0 : onCloseClick();
} })))));
};
export { ChannelSettingsUI as default };
//# sourceMappingURL=ChannelSettingsUI.js.map