UNPKG

@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
'use strict'; var React = require('react'); var utils = require('../../chunks/bundle-1F9guuKw.js'); var ui_Modal = require('../../chunks/bundle-BFmC2V1o.js'); var LocalizationContext = require('../../chunks/bundle-ClT0IexP.js'); var MediaQueryContext = require('../../chunks/bundle-DDUAkmTu.js'); var ui_TextButton = require('../../ui/TextButton.js'); var ui_Label = require('../../chunks/bundle-DxZzcGya.js'); var index = require('../../chunks/bundle-CskFALvU.js'); var useChannelSettings = require('../../chunks/bundle-_yh4eC6v.js'); var useSendbird = require('../../chunks/bundle-on0zTbLT.js'); require('../../chunks/bundle-jAsAzWpU.js'); require('react-dom'); require('../../ui/IconButton.js'); require('../../ui/Button.js'); require('../../ui/Icon.js'); require('../../chunks/bundle-BNgfU9I_.js'); require('../../chunks/bundle-D-_6Kk3L.js'); require('../../chunks/bundle-BXuNw6bR.js'); require('../../chunks/bundle-mNJHRgJ3.js'); require('@sendbird/chat/groupChannel'); require('../../utils/message/getOutgoingMessageState.js'); require('../../chunks/bundle-BVn2UMtk.js'); require('../../chunks/bundle-DvHjgbFi.js'); require('../../chunks/bundle-DS7dko_G.js'); require('../../chunks/bundle-DZN-28o5.js'); require('../../chunks/bundle-Buar9ys-.js'); require('../../chunks/bundle-BSCZWP_l.js'); require('../../chunks/bundle-iF1pW7_s.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