diff options
author | Vitaly Takmazov | 2019-05-04 21:13:12 +0300 |
---|---|---|
committer | Vitaly Takmazov | 2023-01-13 10:37:54 +0300 |
commit | f470636a70943a8ecad8bddc791a1c2dddd28e1e (patch) | |
tree | c43d109d88adbde9a696084070cdd92c6b9a004b /vnext/src/ui/Avatar.js | |
parent | 3d7d213e3ddc5bf4f71d536f31677b768aa3b7c0 (diff) |
Components -> UI
Diffstat (limited to 'vnext/src/ui/Avatar.js')
-rw-r--r-- | vnext/src/ui/Avatar.js | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/vnext/src/ui/Avatar.js b/vnext/src/ui/Avatar.js new file mode 100644 index 00000000..dda5449f --- /dev/null +++ b/vnext/src/ui/Avatar.js @@ -0,0 +1,44 @@ +import React, { memo } from 'react'; +import PropTypes from 'prop-types'; +import { Link } from 'react-router-dom'; + +import { UserType } from './Types'; + +import Icon from './Icon'; + +import './Avatar.css'; + +function Avatar({ user, style, link, children}) { + return ( + <div className="Avatar" style={style}> + <div className="msg-avatar"> + { + user.uname ? + <Link to={{ pathname: link || `/${user.uname}/` }}> + {user.avatar ? + <img src={user.avatar} alt={`${user.uname}`} /> + : <Icon name="ei-spinner" size="m" />} + </Link> + : <Icon name="ei-spinner" size="m" /> + } + </div> + <div style={{ display: 'flex', flexDirection: 'column', justifyContent: 'center' }}> + <span> + <Link to={{ pathname: `/${user.uname}/` }}> + <span>{user.uname}</span> + </Link> + </span> + {children} + </div> + </div> + ); +} + +export default memo(Avatar); + +Avatar.propTypes = { + user: UserType, + link: PropTypes.string, + style: PropTypes.object, + children: PropTypes.node +}; |