@sendbird/uikit-react
Version:
Sendbird UIKit for React: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.
138 lines (130 loc) • 9.07 kB
JavaScript
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var React = require('react');
var EditUserProfile_context = require('../context.js');
var LocalizationContext = require('../../chunks/bundle-DPDyqKIJ.js');
var ui_Modal = require('../../chunks/bundle-DZlJeh0V.js');
require('../../chunks/bundle-Conb-pOy.js');
var ui_Label = require('../../chunks/bundle-zgmRG2KL.js');
var ui_Button = require('../../ui/Button.js');
var ui_Input = require('../../ui/Input.js');
var ui_Avatar = require('../../chunks/bundle-B7KG10z2.js');
var ui_TextButton = require('../../ui/TextButton.js');
var ui_Icon = require('../../ui/Icon.js');
var useSendbird = require('../../chunks/bundle-Bq15P9qk.js');
require('../../chunks/bundle-BbrBawlX.js');
require('../../chunks/bundle-Cyl6_qLo.js');
require('react-dom');
require('../../chunks/bundle-CkQrhwR6.js');
require('../../chunks/bundle-Fv6PNPGZ.js');
require('../../ui/IconButton.js');
require('../../chunks/bundle-t8BQsgL5.js');
require('../../ui/ImageRenderer.js');
require('../../chunks/bundle-C99t7tzf.js');
require('../../chunks/bundle-DurllD3r.js');
require('../../chunks/bundle-B19RHFpR.js');
require('../../chunks/bundle-Cfh78Xnm.js');
require('@sendbird/chat');
require('@sendbird/chat/groupChannel');
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 EditUserProfileUIView = function (_a) {
var _b;
var formRef = _a.formRef, inputRef = _a.inputRef, onThemeChange = _a.onThemeChange, setProfileImage = _a.setProfileImage;
var state = useSendbird.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 = LocalizationContext.useLocalization().stringSet;
var _c = React.useState(null), currentImg = _c[0], setCurrentImg = _c[1];
var hiddenInputRef = React.useRef(null);
return (React__default.default.createElement("form", { className: "sendbird-edit-user-profile", ref: formRef, onSubmit: function (e) { e.preventDefault(); } },
React__default.default.createElement("section", { className: "sendbird-edit-user-profile__img" },
React__default.default.createElement(ui_Input.InputLabel, null, stringSet.EDIT_PROFILE__IMAGE_LABEL),
React__default.default.createElement("div", { className: "sendbird-edit-user-profile__img__avatar" },
React__default.default.createElement(ui_Avatar.Avatar, { width: "80px", height: "80px", src: currentImg || (user === null || user === void 0 ? void 0 : user.profileUrl) })),
React__default.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.default.createElement(ui_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.default.createElement(ui_Label.Label, { type: ui_Label.LabelTypography.BUTTON_1, color: ui_Label.LabelColors.PRIMARY }, stringSet.EDIT_PROFILE__IMAGE_UPLOAD))),
React__default.default.createElement("section", { className: "sendbird-edit-user-profile__name" },
React__default.default.createElement(ui_Input.InputLabel, null, stringSet.EDIT_PROFILE__NICKNAME_LABEL),
React__default.default.createElement(ui_Input.default, { 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.default.createElement("section", { className: "sendbird-edit-user-profile__userid" },
React__default.default.createElement(ui_Input.InputLabel, null, stringSet.EDIT_PROFILE__USERID_LABEL),
React__default.default.createElement(ui_Input.default, { disabled: true, name: "sendbird-edit-user-profile__userid__input", value: user === null || user === void 0 ? void 0 : user.userId })),
React__default.default.createElement("section", { className: "sendbird-edit-user-profile__theme" },
React__default.default.createElement(ui_Input.InputLabel, null, stringSet.EDIT_PROFILE__THEME_LABEL),
React__default.default.createElement("div", { className: "sendbird-edit-user-profile__theme__theme-icon" }, theme === 'dark'
? (React__default.default.createElement(ui_Icon.default, { onClick: function () {
setCurrentTheme('light');
onThemeChange === null || onThemeChange === void 0 ? void 0 : onThemeChange('light');
}, type: ui_Icon.IconTypes.TOGGLE_ON, width: 44, height: 24 }))
: (React__default.default.createElement(ui_Icon.default, { onClick: function () {
setCurrentTheme('dark');
onThemeChange === null || onThemeChange === void 0 ? void 0 : onThemeChange('dark');
}, type: ui_Icon.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.useSendbird(), state = _b.state, actions = _b.actions;
var inputRef = React.useRef(null);
var formRef = React.useRef(null);
var _c = React.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 = EditUserProfile_context.useEditUserProfileContext();
var onEditProfile = editProfileContext.onEditProfile, onCancel = editProfileContext.onCancel, onThemeChange = editProfileContext.onThemeChange;
var stringSet = React.useContext(LocalizationContext.LocalizationContext).stringSet;
var _a = useEditUserProfileUISates({ onEditProfile: onEditProfile }), formRef = _a.formRef, inputRef = _a.inputRef, updateUserInfo = _a.updateUserInfo, setProfileImage = _a.setProfileImage;
return (React__default.default.createElement(ui_Modal.Modal, { titleText: stringSet.EDIT_PROFILE__TITLE, submitText: stringSet.BUTTON__SAVE, type: ui_Button.ButtonTypes.PRIMARY, onCancel: onCancel, isFullScreenOnMobile: true, onSubmit: updateUserInfo },
React__default.default.createElement(EditUserProfileUIView, { formRef: formRef, inputRef: inputRef, setProfileImage: setProfileImage, onThemeChange: onThemeChange })));
};
exports.EditUserProfileUI = EditUserProfileUI;
exports.EditUserProfileUIView = EditUserProfileUIView;
exports.default = EditUserProfileUI;
exports.useEditUserProfileUISates = useEditUserProfileUISates;
//# sourceMappingURL=EditUserProfileUI.js.map