UNPKG

@sendbird/uikit-react

Version:

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

127 lines (123 loc) 8.38 kB
import React__default, { useState, useRef, useContext } from 'react'; import { useEditUserProfileContext } from '../context.js'; import { u as useLocalization, L as LocalizationContext } from '../../chunks/bundle-Del33VzI.js'; import { M as Modal } from '../../chunks/bundle-CtQtfJlT.js'; import '../../chunks/bundle-yl5d1NoZ.js'; import { L as Label, a as LabelTypography, b as LabelColors } from '../../chunks/bundle-viBng0Kh.js'; import { ButtonTypes } from '../../ui/Button.js'; import Input, { InputLabel } from '../../ui/Input.js'; import { A as Avatar } from '../../chunks/bundle-CAEBoiEz.js'; import TextButton from '../../ui/TextButton.js'; import Icon, { IconTypes } from '../../ui/Icon.js'; import { u as useSendbird } from '../../chunks/bundle-i_3w58Zd.js'; import '../../chunks/bundle-C1dqPUnT.js'; import '../../chunks/bundle-BZGITC2g.js'; import 'react-dom'; import '../../chunks/bundle-MlG9piGf.js'; import '../../chunks/bundle-DBhJIxHw.js'; import '../../ui/IconButton.js'; import '../../chunks/bundle-DGh2T5IL.js'; import '../../ui/ImageRenderer.js'; import '../../chunks/bundle-Dl_v8XoN.js'; import '../../chunks/bundle-Bokm7tQ9.js'; import '../../chunks/bundle-BUYU9H94.js'; import '../../chunks/bundle-CqLLOVG5.js'; import '@sendbird/chat'; import '@sendbird/chat/groupChannel'; import '@sendbird/chat/openChannel'; var EditUserProfileUIView = function (_a) { var _b; var formRef = _a.formRef, inputRef = _a.inputRef, onThemeChange = _a.onThemeChange, setProfileImage = _a.setProfileImage; var state = useSendbird().state; var stores = state.stores, config = state.config; var theme = config.theme, setCurrentTheme = config.setCurrentTheme; var user = (_b = stores.userStore) === null || _b === void 0 ? void 0 : _b.user; var stringSet = useLocalization().stringSet; var _c = useState(null), currentImg = _c[0], setCurrentImg = _c[1]; var hiddenInputRef = useRef(null); return (React__default.createElement("form", { className: "sendbird-edit-user-profile", ref: formRef, onSubmit: function (e) { e.preventDefault(); } }, React__default.createElement("section", { className: "sendbird-edit-user-profile__img" }, React__default.createElement(InputLabel, null, stringSet.EDIT_PROFILE__IMAGE_LABEL), React__default.createElement("div", { className: "sendbird-edit-user-profile__img__avatar" }, React__default.createElement(Avatar, { width: "80px", height: "80px", src: currentImg || (user === null || user === void 0 ? void 0 : user.profileUrl) })), React__default.createElement("input", { ref: hiddenInputRef, type: "file", accept: "image/gif, image/jpeg, image/png", style: { display: 'none' }, onChange: function (e) { if (e.target.files) { setCurrentImg(URL.createObjectURL(e.target.files[0])); setProfileImage(e.target.files[0]); } if (hiddenInputRef.current) { hiddenInputRef.current.value = ''; } } }), React__default.createElement(TextButton, { className: "sendbird-edit-user-profile__img__avatar-button", disableUnderline: true, onClick: function () { var _a; return (_a = hiddenInputRef.current) === null || _a === void 0 ? void 0 : _a.click(); } }, React__default.createElement(Label, { type: LabelTypography.BUTTON_1, color: LabelColors.PRIMARY }, stringSet.EDIT_PROFILE__IMAGE_UPLOAD))), React__default.createElement("section", { className: "sendbird-edit-user-profile__name" }, React__default.createElement(InputLabel, null, stringSet.EDIT_PROFILE__NICKNAME_LABEL), React__default.createElement(Input, { required: (user === null || user === void 0 ? void 0 : user.nickname) !== '', name: "sendbird-edit-user-profile__name__input", ref: inputRef, value: user === null || user === void 0 ? void 0 : user.nickname, placeHolder: stringSet.EDIT_PROFILE__NICKNAME_PLACEHOLDER })), React__default.createElement("section", { className: "sendbird-edit-user-profile__userid" }, React__default.createElement(InputLabel, null, stringSet.EDIT_PROFILE__USERID_LABEL), React__default.createElement(Input, { disabled: true, name: "sendbird-edit-user-profile__userid__input", value: user === null || user === void 0 ? void 0 : user.userId })), React__default.createElement("section", { className: "sendbird-edit-user-profile__theme" }, React__default.createElement(InputLabel, null, stringSet.EDIT_PROFILE__THEME_LABEL), React__default.createElement("div", { className: "sendbird-edit-user-profile__theme__theme-icon" }, theme === 'dark' ? (React__default.createElement(Icon, { onClick: function () { setCurrentTheme('light'); onThemeChange === null || onThemeChange === void 0 ? void 0 : onThemeChange('light'); }, type: IconTypes.TOGGLE_ON, width: 44, height: 24 })) : (React__default.createElement(Icon, { onClick: function () { setCurrentTheme('dark'); onThemeChange === null || onThemeChange === void 0 ? void 0 : onThemeChange('dark'); }, type: IconTypes.TOGGLE_OFF, width: 44, height: 24 })))))); }; var handleUpdateUserInfo = function (_a) { var _b, _c, _d; var globalContext = _a.globalContext, formRef = _a.formRef, inputRef = _a.inputRef, profileImage = _a.profileImage, onEditProfile = _a.onEditProfile, updateUserInfo = _a.updateUserInfo; var stores = globalContext.stores; var sdk = stores.sdkStore.sdk; var user = stores.userStore.user; if ((user === null || user === void 0 ? void 0 : user.nickname) !== '' && !inputRef.current.value) { (_c = (_b = formRef.current).reportValidity) === null || _c === void 0 ? void 0 : _c.call(_b); // might not work in explorer return; } sdk === null || sdk === void 0 ? void 0 : sdk.updateCurrentUserInfo({ nickname: (_d = inputRef === null || inputRef === void 0 ? void 0 : inputRef.current) === null || _d === void 0 ? void 0 : _d.value, profileImage: profileImage !== null && profileImage !== void 0 ? profileImage : undefined, }).then(function (updatedUser) { updateUserInfo(updatedUser); onEditProfile === null || onEditProfile === void 0 ? void 0 : onEditProfile(updatedUser); }); }; var useEditUserProfileUISates = function (_a) { var onEditProfile = _a.onEditProfile; var _b = useSendbird(), state = _b.state, actions = _b.actions; var inputRef = useRef(null); var formRef = useRef(null); var _c = useState(null), profileImage = _c[0], setProfileImage = _c[1]; var updateUserInfo = function () { handleUpdateUserInfo({ globalContext: state, formRef: formRef, inputRef: inputRef, profileImage: profileImage, onEditProfile: onEditProfile, updateUserInfo: actions.updateUserInfo, }); }; return { formRef: formRef, inputRef: inputRef, updateUserInfo: updateUserInfo, profileImage: profileImage, setProfileImage: setProfileImage, }; }; var EditUserProfileUI = function () { var editProfileContext = useEditUserProfileContext(); var onEditProfile = editProfileContext.onEditProfile, onCancel = editProfileContext.onCancel, onThemeChange = editProfileContext.onThemeChange; var stringSet = useContext(LocalizationContext).stringSet; var _a = useEditUserProfileUISates({ onEditProfile: onEditProfile }), formRef = _a.formRef, inputRef = _a.inputRef, updateUserInfo = _a.updateUserInfo, setProfileImage = _a.setProfileImage; return (React__default.createElement(Modal, { titleText: stringSet.EDIT_PROFILE__TITLE, submitText: stringSet.BUTTON__SAVE, type: ButtonTypes.PRIMARY, onCancel: onCancel, isFullScreenOnMobile: true, onSubmit: updateUserInfo }, React__default.createElement(EditUserProfileUIView, { formRef: formRef, inputRef: inputRef, setProfileImage: setProfileImage, onThemeChange: onThemeChange }))); }; export { EditUserProfileUI, EditUserProfileUIView, EditUserProfileUI as default, useEditUserProfileUISates }; //# sourceMappingURL=EditUserProfileUI.js.map