UNPKG

@sendbird/uikit-react

Version:

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

121 lines (114 loc) 7.71 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var _tslib = require('../../chunks/bundle-3pIN38MR.js'); var React = require('react'); var useChannelSettings = require('../../chunks/bundle-DDSgAZ7n.js'); var LocalizationContext = require('../../chunks/bundle-O9GJGA-U.js'); var ChannelSettings_hooks_useMenuList = require('../hooks/useMenuList.js'); var utils = require('../../chunks/bundle-CJhoVxdz.js'); var ChannelSettings_components_ChannelSettingsHeader = require('./ChannelSettingsHeader.js'); var ui_PlaceHolder = require('../../ui/PlaceHolder.js'); var ui_Label = require('../../chunks/bundle-DONg2mag.js'); var ui_Icon = require('../../ui/Icon.js'); var ChannelSettings_components_ChannelProfile = require('./ChannelProfile.js'); var ChannelSettings_components_LeaveChannel = require('./LeaveChannel.js'); var ChannelSettings_components_ChannelSettingsMenuItem = require('./ChannelSettingsMenuItem.js'); var ChannelSettings_components_ChannelSettingMenuList = require('./ChannelSettingMenuList.js'); var useSendbird = require('../../chunks/bundle-CMlV_h38.js'); var MutedMemberList = require('../../chunks/bundle-DlkOn50n.js'); var MemberList = require('../../chunks/bundle-BcNQT2_6.js'); require('../../chunks/bundle-Sfn_RLlP.js'); require('../../chunks/bundle-CyENaxLd.js'); require('@sendbird/chat/groupChannel'); require('../../chunks/bundle-ByzBZitI.js'); require('../../chunks/bundle-CZLKAZCV.js'); require('../../chunks/bundle-C562G-JW.js'); require('../../chunks/bundle-BRv5cK_w.js'); require('../../chunks/bundle-CIulWkOG.js'); require('../../ui/Badge.js'); require('../../ui/Toggle.js'); require('../../ui/Header.js'); require('../../chunks/bundle-DlPLN3bg.js'); require('../../ui/TextButton.js'); require('../../chunks/bundle-Bj-0Jsyi.js'); require('../../ui/IconButton.js'); require('../../ui/Loader.js'); require('../../ui/ChannelAvatar.js'); require('../../chunks/bundle-BikLdyZe.js'); require('../../ui/ImageRenderer.js'); require('../../chunks/bundle-XIN-6-ar.js'); require('../../chunks/bundle-BewOM8Bd.js'); require('./EditDetailsModal.js'); require('../../chunks/bundle-DfzBeTAr.js'); require('react-dom'); require('../../ui/Button.js'); require('../../ui/Input.js'); require('../../chunks/bundle-DrGYNNB5.js'); require('../../utils/message/getOutgoingMessageState.js'); require('../../chunks/bundle-BROd4sV1.js'); require('../../chunks/bundle-BnDEMyZ4.js'); require('../../chunks/bundle-CiHUpz7L.js'); require('../../chunks/bundle-ajPzzYnD.js'); require('@sendbird/chat/message'); require('@sendbird/chat'); require('@sendbird/chat/openChannel'); require('../../chunks/bundle-DGI3KmLP.js'); require('../../chunks/bundle-BbP1ND3d.js'); require('../../ui/SortByRow.js'); require('../../ui/UserListItem.js'); require('../../ui/MutedAvatarOverlay.js'); require('../../ui/Checkbox.js'); require('../../ui/UserProfile.js'); require('../../sendbirdSelectors.js'); require('../../chunks/bundle-C8f_4-N0.js'); require('../../chunks/bundle-CbBu6KFu.js'); require('@sendbird/uikit-tools'); require('../../chunks/bundle-BmFe2W3e.js'); function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; } var React__default = /*#__PURE__*/_interopDefaultCompat(React); var ChannelSettingsUI = function (props) { var _a = utils.deleteNullish(props), _b = _a.renderHeader, renderHeader = _b === void 0 ? function (props) { return React__default.default.createElement(ChannelSettings_components_ChannelSettingsHeader.ChannelSettingsHeader, _tslib.__assign({}, props)); } : _b, renderLeaveChannel = _a.renderLeaveChannel, renderChannelProfile = _a.renderChannelProfile, _c = _a.renderModerationPanel, renderModerationPanel = _c === void 0 ? function (props) { return React__default.default.createElement(ChannelSettings_components_ChannelSettingMenuList.MenuListByRole, _tslib.__assign({}, props)); } : _c, renderPlaceholderError = _a.renderPlaceholderError, renderPlaceholderLoading = _a.renderPlaceholderLoading; var state = useSendbird.useSendbird().state; var isOnline = state.config.isOnline; var _d = useChannelSettings.useChannelSettings().state, channel = _d.channel, invalidChannel = _d.invalidChannel, onCloseClick = _d.onCloseClick, loading = _d.loading; var stringSet = LocalizationContext.useLocalization().stringSet; var menuItems = ChannelSettings_hooks_useMenuList.useMenuItems(); var _e = React.useState(false), showLeaveChannelModal = _e[0], setShowLeaveChannelModal = _e[1]; if (loading) { if (renderPlaceholderLoading) return renderPlaceholderLoading(); return React__default.default.createElement(ui_PlaceHolder.default, { type: ui_PlaceHolder.PlaceHolderTypes.LOADING }); } var headerProps = { onCloseClick: onCloseClick }; if (invalidChannel || !channel) { return (React__default.default.createElement("div", null, renderHeader(headerProps), React__default.default.createElement("div", null, renderPlaceholderError ? renderPlaceholderError() : React__default.default.createElement(ui_PlaceHolder.default, { type: ui_PlaceHolder.PlaceHolderTypes.WRONG })))); } return (React__default.default.createElement(React__default.default.Fragment, null, renderHeader(headerProps), React__default.default.createElement("div", { className: "sendbird-channel-settings__scroll-area" }, (renderChannelProfile === null || renderChannelProfile === void 0 ? void 0 : renderChannelProfile()) || React__default.default.createElement(ChannelSettings_components_ChannelProfile, null), renderModerationPanel === null || renderModerationPanel === void 0 ? void 0 : renderModerationPanel({ menuItems: menuItems }), (renderLeaveChannel === null || renderLeaveChannel === void 0 ? void 0 : renderLeaveChannel()) || (React__default.default.createElement(ChannelSettings_components_ChannelSettingsMenuItem.MenuItem, { className: utils.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.default.createElement(ui_Icon.default, { className: ['sendbird-channel-settings__panel-icon-left', 'sendbird-channel-settings__panel-icon__leave'].join(' '), type: ui_Icon.IconTypes.LEAVE, fillColor: ui_Icon.IconColors.ERROR, height: "24px", width: "24px" })); }, renderMiddle: function () { return (React__default.default.createElement(ui_Label.Label, { type: ui_Label.LabelTypography.SUBTITLE_1, color: ui_Label.LabelColors.ONBACKGROUND_1 }, stringSet.CHANNEL_SETTING__LEAVE_CHANNEL__TITLE)); } })), showLeaveChannelModal && (React__default.default.createElement(ChannelSettings_components_LeaveChannel, { onCancel: function () { setShowLeaveChannelModal(false); }, onSubmit: function () { setShowLeaveChannelModal(false); onCloseClick === null || onCloseClick === void 0 ? void 0 : onCloseClick(); } }))))); }; exports.BannedUserList = MutedMemberList.BannedUserList; exports.MutedMemberList = MutedMemberList.MutedMemberList; exports.OperatorList = MutedMemberList.OperatorList; exports.MemberList = MemberList.MemberList; exports.default = ChannelSettingsUI; //# sourceMappingURL=ChannelSettingsUI.js.map