diff options
| author | eug-vs <eug-vs@keemail.me> | 2020-03-21 17:38:44 +0300 | 
|---|---|---|
| committer | eug-vs <eug-vs@keemail.me> | 2020-03-21 17:38:44 +0300 | 
| commit | 295c6e179ec0f14a10303e01fb6e5b5ef969db79 (patch) | |
| tree | c3a1ff2849fae554af71849ee33ee3dea2146061 /src/components | |
| parent | 7f8ab6802c68c46f988ef012fdc88b09e43a9e54 (diff) | |
| download | chrono-cube-ui-295c6e179ec0f14a10303e01fb6e5b5ef969db79.tar.gz | |
feat: add github avatars to users
Diffstat (limited to 'src/components')
| -rw-r--r-- | src/components/GithubAvatar/GithubAvatar.tsx | 35 | ||||
| -rw-r--r-- | src/components/SolutionCard/SolutionCard.tsx | 9 | 
2 files changed, 37 insertions, 7 deletions
| diff --git a/src/components/GithubAvatar/GithubAvatar.tsx b/src/components/GithubAvatar/GithubAvatar.tsx new file mode 100644 index 0000000..6aab28e --- /dev/null +++ b/src/components/GithubAvatar/GithubAvatar.tsx @@ -0,0 +1,35 @@ +import React from 'react'; + +import { +  Avatar, +  Link, +} from '@material-ui/core'; + +interface PropTypes { +  username: string; +} + +const GithubAvatar: React.FC<PropTypes> = ({ username }) => { +  if (username === 'anonymous') return <Avatar/>; + +  const githubUrl = `https://github.com/${username}`; +  const avatarUrl = githubUrl + '.png'; +  const usernameTokens = username.split(/[ ,.\-_#@;]/g); +  const altText = ( +    (usernameTokens.length > 1)? +      (usernameTokens[0][0] + usernameTokens[1][0]) +    : +      usernameTokens[0][0] +  ).toUpperCase() + +  return ( +    <Link href={githubUrl}> +      <Avatar> +        <img src={avatarUrl} alt={altText} /> +      </Avatar> +    </Link> +  ) +}; + +export default GithubAvatar; + diff --git a/src/components/SolutionCard/SolutionCard.tsx b/src/components/SolutionCard/SolutionCard.tsx index 5adbff9..7ec8888 100644 --- a/src/components/SolutionCard/SolutionCard.tsx +++ b/src/components/SolutionCard/SolutionCard.tsx @@ -6,7 +6,6 @@ import {    CardHeader,    CardContent,    IconButton, -  Avatar,    Grid,    Menu,    MenuItem, @@ -18,6 +17,7 @@ import TimerIcon from '@material-ui/icons/Timer';  import MoreVertIcon from '@material-ui/icons/MoreVert';  import DeleteIcon from '@material-ui/icons/Delete'; +import GithubAvatar from '../GithubAvatar/GithubAvatar';  import { del } from '../../requests'; @@ -77,12 +77,7 @@ const SolutionCard: React.FC<PropTypes> = ({ data, removeThisCard }) => {    return (      <Card className={classes.root}>        <CardHeader -        avatar={ -          author === 'anonymous'? -            (<Avatar/>) -            : -            (<Avatar>{author[0].toUpperCase()}</Avatar>) -        } +        avatar={<GithubAvatar username={author} />}          title={author}          subheader={date.toLocaleString('default', DATE_FORMAT)}          action={ | 
