@sendbird/uikit-react
Version:
Sendbird UIKit for React: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.
82 lines (76 loc) • 4.73 kB
JavaScript
;
var React = require('react');
var utils = require('../../chunks/bundle-CJhoVxdz.js');
var ui_Modal = require('../../chunks/bundle-DfzBeTAr.js');
var LocalizationContext = require('../../chunks/bundle-O9GJGA-U.js');
var MediaQueryContext = require('../../chunks/bundle-DlPLN3bg.js');
var ui_TextButton = require('../../ui/TextButton.js');
var ui_Label = require('../../chunks/bundle-DONg2mag.js');
var index = require('../../chunks/bundle-DrGYNNB5.js');
var useChannelSettings = require('../../chunks/bundle-DDSgAZ7n.js');
var useSendbird = require('../../chunks/bundle-CMlV_h38.js');
require('../../chunks/bundle-3pIN38MR.js');
require('react-dom');
require('../../ui/IconButton.js');
require('../../ui/Button.js');
require('../../ui/Icon.js');
require('../../chunks/bundle-ByzBZitI.js');
require('../../chunks/bundle-BRv5cK_w.js');
require('../../chunks/bundle-CIulWkOG.js');
require('../../chunks/bundle-Bj-0Jsyi.js');
require('@sendbird/chat/groupChannel');
require('../../utils/message/getOutgoingMessageState.js');
require('../../chunks/bundle-BROd4sV1.js');
require('../../chunks/bundle-BnDEMyZ4.js');
require('../../chunks/bundle-CiHUpz7L.js');
require('../../chunks/bundle-CyENaxLd.js');
require('../../chunks/bundle-Sfn_RLlP.js');
require('../../chunks/bundle-CZLKAZCV.js');
require('../../chunks/bundle-C562G-JW.js');
require('@sendbird/chat');
require('@sendbird/chat/openChannel');
function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
var React__default = /*#__PURE__*/_interopDefaultCompat(React);
var LeaveChannel = function (props) {
var _a, _b;
var _c = props.onSubmit, onSubmit = _c === void 0 ? utils.noop : _c, _d = props.onCancel, onCancel = _d === void 0 ? utils.noop : _d;
var _e = useChannelSettings.useChannelSettings().state, channel = _e.channel, onLeaveChannel = _e.onLeaveChannel;
var stringSet = LocalizationContext.useLocalization().stringSet;
var state = useSendbird.useSendbird().state;
var logger = (_a = state === null || state === void 0 ? void 0 : state.config) === null || _a === void 0 ? void 0 : _a.logger;
var isOnline = (_b = state === null || state === void 0 ? void 0 : state.config) === null || _b === void 0 ? void 0 : _b.isOnline;
var isMobile = MediaQueryContext.useMediaQueryContext().isMobile;
var getChannelName = function (channel) {
if (!(channel === null || channel === void 0 ? void 0 : channel.name) && !(channel === null || channel === void 0 ? void 0 : channel.members))
return stringSet.NO_TITLE;
if (index.isDefaultChannelName(channel))
return ((channel === null || channel === void 0 ? void 0 : channel.members) || []).map(function (member) { return member.nickname || stringSet.NO_NAME; }).join(', ');
return channel.name;
};
if (isMobile) {
return (React__default.default.createElement(ui_Modal.Modal, { className: "sendbird-channel-settings__leave--mobile", titleText: getChannelName(channel), hideFooter: true, isCloseOnClickOutside: true, onCancel: onCancel },
React__default.default.createElement(ui_TextButton, { onClick: function () {
logger.info('ChannelSettings: Leaving channel', channel);
channel === null || channel === void 0 ? void 0 : channel.leave().then(function () {
logger.info('ChannelSettings: Leaving channel successful!', channel);
onLeaveChannel === null || onLeaveChannel === void 0 ? void 0 : onLeaveChannel();
});
}, className: "sendbird-channel-settings__leave-label--mobile" },
React__default.default.createElement(ui_Label.Label, { type: ui_Label.LabelTypography.SUBTITLE_1, color: ui_Label.LabelColors.ONBACKGROUND_1 }, stringSet.CHANNEL_PREVIEW_MOBILE_LEAVE))));
}
return (React__default.default.createElement(ui_Modal.Modal, { isFullScreenOnMobile: true, disabled: !isOnline, onCancel: onCancel, onSubmit: function () {
logger.info('ChannelSettings: Leaving channel', channel);
channel === null || channel === void 0 ? void 0 : channel.leave().then(function () {
logger.info('ChannelSettings: Leaving channel successful!', channel);
// is for backward compactability
if (onLeaveChannel) {
onLeaveChannel();
}
else {
onSubmit();
}
});
}, submitText: stringSet.MODAL__LEAVE_CHANNEL__FOOTER, titleText: stringSet.MODAL__LEAVE_CHANNEL__TITLE }));
};
module.exports = LeaveChannel;
//# sourceMappingURL=LeaveChannel.js.map