UNPKG

@selfcommunity/react-ui

Version:

React UI Components to integrate a Community created with SelfCommunity Platform.

86 lines (85 loc) 5.27 kB
import { __rest } from "tslib"; import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime"; import { useCallback, useState } from 'react'; import { useThemeProps } from '@mui/system'; import classNames from 'classnames'; import { PREFIX } from '../../constants'; import { Button, Drawer, IconButton, Paper, Typography, Box, styled, Icon } from '@mui/material'; import { FormattedMessage } from 'react-intl'; import PublicInfo from '../../../UserProfileEdit/Section/PublicInfo'; import { SCPreferences, useSCContext, useSCFetchUser, useSCPreferences, useSCUser } from '@selfcommunity/react-core'; import UserAvatar from '../../../../shared/UserAvatar'; import ChangePicture from '../../../ChangePicture'; import ChangeCover from '../../../ChangeCover'; import { DEFAULT_FIELDS } from '../../../../constants/UserProfile'; const classes = { root: `${PREFIX}-profile-root`, title: `${PREFIX}-profile-title`, icon: `${PREFIX}-profile-icon`, cover: `${PREFIX}-profile-cover`, avatar: `${PREFIX}-profile-avatar`, changePicture: `${PREFIX}-profile-change-picture`, changeCover: `${PREFIX}-profile-change-cover`, publicInfo: `${PREFIX}-profile-public-info` }; const Root = styled(Box, { name: PREFIX, slot: 'ProfileRoot' })(() => ({})); const DrawerRoot = styled(Drawer, { name: PREFIX, slot: 'ProfileDrawerRoot' })(() => ({})); export default function Profile(inProps) { var _a; // PROPS const props = useThemeProps({ props: inProps, name: PREFIX }); const { className, fields = [...DEFAULT_FIELDS], user = null, onCompleteAction } = props, rest = __rest(props, ["className", "fields", "user", "onCompleteAction"]); // STATE const [anchorEl, setAnchorEl] = useState(null); // PREFERENCES const scPreferences = useSCPreferences(); // CONTEXT const scContext = useSCContext(); const scUserContext = useSCUser(); // HOOKS const { scUser, setSCUser } = useSCFetchUser({ id: (_a = scUserContext === null || scUserContext === void 0 ? void 0 : scUserContext.user) === null || _a === void 0 ? void 0 : _a.id, user }); const hasBadge = scUser && scUser.community_badge; // HANDLERS const handleOpen = useCallback((event) => { setAnchorEl(event.currentTarget); }, []); const handleClose = useCallback(() => { setAnchorEl(null); }, []); /** * Handles Change Avatar * If avatar === null reset the avatar with auto-generated image * @param avatar */ function handleChangeAvatar(avatar) { if (avatar) { setSCUser(Object.assign({}, scUser, { avatar: avatar.avatar })); } else { setSCUser(Object.assign({}, scUser, { avatar: `${scContext.settings.portal}/api/v2/avatar/${scUser.id}` })); } onCompleteAction(); } const _backgroundCover = Object.assign({}, ((scUser === null || scUser === void 0 ? void 0 : scUser.cover) ? { background: `url('${scUser.cover}') center / cover` } : { background: `url('${scPreferences.preferences[SCPreferences.IMAGES_USER_DEFAULT_COVER].value}') center / cover` })); /** * Handles Change Cover * Only if scUser.id === scUserContext.user.id * @param cover */ function handleChangeCover(cover) { setSCUser(Object.assign({}, scUser, { cover: cover })); onCompleteAction(); } return (_jsxs(Root, Object.assign({ className: classNames(classes.root, className) }, rest, { children: [_jsx(Typography, Object.assign({ variant: "h4", className: classes.title, alignSelf: "self-start" }, { children: _jsx(FormattedMessage, { id: "ui.onBoardingWidget.profile", defaultMessage: "ui.onBoardingWidget.profile" }) })), _jsx(Typography, Object.assign({ alignSelf: "self-start" }, { children: _jsx(FormattedMessage, { id: "ui.onBoardingWidget.step.profile.summary", defaultMessage: "ui.onBoardingWidget.step.profile.summary" }) })), _jsx(Button, Object.assign({ variant: "outlined", size: "small", color: "primary", onClick: handleOpen }, { children: _jsx(FormattedMessage, { id: "ui.onBoardingWidget.step.profile.button", defaultMessage: "ui.onBoardingWidget.step.profile.button" }) })), _jsxs(DrawerRoot, Object.assign({ anchor: "right", open: Boolean(anchorEl), onClose: handleClose }, { children: [_jsx(IconButton, Object.assign({ className: classes.icon, onClick: handleClose }, { children: _jsx(Icon, { children: "close" }) })), _jsxs(Paper, Object.assign({ style: _backgroundCover, classes: { root: classes.cover } }, { children: [_jsx(Box, Object.assign({ className: classes.avatar }, { children: _jsx(UserAvatar, Object.assign({ hide: !hasBadge }, { children: _jsx("img", { src: (scUser === null || scUser === void 0 ? void 0 : scUser.avatar) ? scUser.avatar : '' }) })) })), _jsxs(_Fragment, { children: [_jsx(ChangePicture, { iconButton: true, onChange: handleChangeAvatar, className: classes.changePicture }), _jsx("div", Object.assign({ className: classes.changeCover }, { children: _jsx(ChangeCover, { onChange: handleChangeCover }) }))] })] })), _jsx(Box, Object.assign({ className: classes.publicInfo }, { children: _jsx(PublicInfo, { fields: fields, onEditSuccess: onCompleteAction }) }))] }))] }))); }