@sendbird/uikit-react
Version:
Sendbird UIKit for React: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.
60 lines (57 loc) • 4.21 kB
JavaScript
import React__default, { useContext } from 'react';
import { L as LocalizationContext } from '../chunks/bundle-DxLnjDoJ.js';
import { u as useUserProfileContext } from '../chunks/bundle-tDk7wyaM.js';
import { getCreateGroupChannel } from '../sendbirdSelectors.js';
import { A as Avatar } from '../chunks/bundle-Dgt7lb2O.js';
import { L as Label, a as LabelTypography, b as LabelColors } from '../chunks/bundle-FZ_FdxZT.js';
import Button, { ButtonTypes } from './Button.js';
import { u as useSendbird } from '../chunks/bundle-BnaoVUUl.js';
import '../chunks/bundle-DlZj_j5B.js';
import '../chunks/bundle-Dhutxl0X.js';
import '../chunks/bundle-D89Qj0P4.js';
import '../chunks/bundle-D9lZlE3H.js';
import '../chunks/bundle-CaW4IP0_.js';
import './ImageRenderer.js';
import '../chunks/bundle-h43SVTxb.js';
import './Icon.js';
import '../chunks/bundle-C1jTnXNH.js';
import '../chunks/bundle-C8kxBudB.js';
import '@sendbird/chat';
import '@sendbird/chat/groupChannel';
import '@sendbird/chat/openChannel';
function UserProfile(_a) {
var _b, _c;
var user = _a.user, currentUserId = _a.currentUserId, _d = _a.disableMessaging, disableMessaging = _d === void 0 ? false : _d, onSuccess = _a.onSuccess;
var state = useSendbird().state;
var createChannel = getCreateGroupChannel(state);
var logger = (_b = state === null || state === void 0 ? void 0 : state.config) === null || _b === void 0 ? void 0 : _b.logger;
var stringSet = useContext(LocalizationContext).stringSet;
var currentUserId_ = currentUserId || ((_c = state === null || state === void 0 ? void 0 : state.config) === null || _c === void 0 ? void 0 : _c.userId);
var onStartDirectMessage = useUserProfileContext().onStartDirectMessage;
return (React__default.createElement("div", { className: "sendbird__user-profile" },
React__default.createElement("section", { className: "sendbird__user-profile-avatar" },
React__default.createElement(Avatar, { height: "80px", width: "80px", src: user === null || user === void 0 ? void 0 : user.profileUrl })),
React__default.createElement("section", { className: "sendbird__user-profile-name" },
React__default.createElement(Label, { type: LabelTypography.H_2, color: LabelColors.ONBACKGROUND_1 }, (user === null || user === void 0 ? void 0 : user.nickname) || stringSet.NO_NAME)),
((user === null || user === void 0 ? void 0 : user.userId) !== currentUserId_) && !disableMessaging && (React__default.createElement("section", { className: "sendbird__user-profile-message" },
React__default.createElement(Button, { type: ButtonTypes.SECONDARY, onClick: function () {
// Create 1:1 channel
var params = {
isDistinct: false,
invitedUserIds: (user === null || user === void 0 ? void 0 : user.userId) ? [user === null || user === void 0 ? void 0 : user.userId] : [],
operatorUserIds: [currentUserId_],
};
onSuccess === null || onSuccess === void 0 ? void 0 : onSuccess();
createChannel(params)
.then(function (groupChannel) {
logger.info('UserProfile, channel create', groupChannel);
onStartDirectMessage === null || onStartDirectMessage === void 0 ? void 0 : onStartDirectMessage(groupChannel);
});
} }, stringSet.USER_PROFILE__MESSAGE))),
React__default.createElement("div", { className: "sendbird__user-profile-separator" }),
React__default.createElement("section", { className: "sendbird__user-profile-userId" },
React__default.createElement(Label, { className: "sendbird__user-profile-userId--label", type: LabelTypography.CAPTION_2, color: LabelColors.ONBACKGROUND_2 }, stringSet.USER_PROFILE__USER_ID),
React__default.createElement(Label, { className: "sendbird__user-profile-userId--value", type: LabelTypography.BODY_1, color: LabelColors.ONBACKGROUND_1 }, user === null || user === void 0 ? void 0 : user.userId))));
}
export { UserProfile as default };
//# sourceMappingURL=UserProfile.js.map