UNPKG

@sendbird/uikit-react

Version:

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

73 lines (70 loc) 4.46 kB
import React__default, { useContext, useState, useMemo } from 'react'; import { u as useChannelSettings } from '../../chunks/bundle-ab1EZFfD.js'; import { L as LocalizationContext } from '../../chunks/bundle-DxLnjDoJ.js'; import ChannelAvatar from '../../ui/ChannelAvatar.js'; import TextButton from '../../ui/TextButton.js'; import { L as Label, a as LabelTypography, b as LabelColors } from '../../chunks/bundle-FZ_FdxZT.js'; import EditDetails from './EditDetailsModal.js'; import { u as useSendbird } from '../../chunks/bundle-BnaoVUUl.js'; import { a as isDefaultChannelName } from '../../chunks/bundle-C5Cl3Igw.js'; import '../../chunks/bundle-DlZj_j5B.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-CaW4IP0_.js'; import '../../chunks/bundle-tDk7wyaM.js'; import '../../chunks/bundle-Dhutxl0X.js'; import '../../chunks/bundle-D89Qj0P4.js'; import '../../chunks/bundle-Dgt7lb2O.js'; import '../../ui/ImageRenderer.js'; import '../../chunks/bundle-h43SVTxb.js'; import '../../ui/Icon.js'; import '../../chunks/bundle-DGOBflIQ.js'; import '../../chunks/bundle-Bv6iXkjg.js'; import '../../chunks/bundle-BDItDVZl.js'; import 'react-dom'; import '../../chunks/bundle-DWJPyrDa.js'; import '../../ui/IconButton.js'; import '../../ui/Button.js'; import '../../ui/Input.js'; import '@sendbird/chat'; import '@sendbird/chat/openChannel'; import '../../utils/message/getOutgoingMessageState.js'; import '../../chunks/bundle-OJHU7Q3U.js'; import '../../chunks/bundle-DZaN4z9l.js'; import '../../chunks/bundle-0bJlK18Z.js'; var ChannelProfile = function () { var _a, _b, _c; var state = useSendbird().state; var channel = useChannelSettings().state.channel; var stringSet = useContext(LocalizationContext).stringSet; var _d = useState(false), showModal = _d[0], setShowModal = _d[1]; var userId = (_a = state === null || state === void 0 ? void 0 : state.config) === null || _a === void 0 ? void 0 : _a.userId; var theme = ((_b = state === null || state === void 0 ? void 0 : state.config) === null || _b === void 0 ? void 0 : _b.theme) || 'light'; var isOnline = (_c = state === null || state === void 0 ? void 0 : state.config) === null || _c === void 0 ? void 0 : _c.isOnline; var disabled = !isOnline; var channelName = useMemo(function () { if (!(channel === null || channel === void 0 ? void 0 : channel.name) && !(channel === null || channel === void 0 ? void 0 : channel.members)) return stringSet.NO_TITLE; if (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; }, [channel === null || channel === void 0 ? void 0 : channel.name, channel === null || channel === void 0 ? void 0 : channel.joinedMemberCount]); return (React__default.createElement("div", { className: "sendbird-channel-profile" }, React__default.createElement("div", { className: "sendbird-channel-profile--inner" }, React__default.createElement("div", { className: "sendbird-channel-profile__avatar" }, React__default.createElement(ChannelAvatar, { channel: channel, userId: userId, theme: theme, width: 80, height: 80 })), React__default.createElement(Label, { className: "sendbird-channel-profile__title", type: LabelTypography.SUBTITLE_2, color: LabelColors.ONBACKGROUND_1 }, channelName), React__default.createElement(TextButton, { disabled: disabled, className: "sendbird-channel-profile__edit", onClick: function () { if (disabled) { return; } setShowModal(true); }, disableUnderline: true }, React__default.createElement(Label, { type: LabelTypography.BUTTON_1, color: disabled ? LabelColors.ONBACKGROUND_2 : LabelColors.PRIMARY }, stringSet.CHANNEL_SETTING__PROFILE__EDIT)), showModal && (React__default.createElement(EditDetails, { onCancel: function () { return setShowModal(false); }, onSubmit: function () { return setShowModal(false); } }))))); }; export { ChannelProfile as default }; //# sourceMappingURL=ChannelProfile.js.map