diff options
| author | Eugene Sokolov <eug-vs@keemail.me> | 2020-08-14 05:06:01 +0300 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-08-14 05:06:01 +0300 | 
| commit | a6d2d1d833116772178125b3e047e0811131c0e0 (patch) | |
| tree | 022abcb444cda09f98c2d43accc2fdd85aeb2a82 /src/components | |
| parent | dc0d09f568ca9eeda4978c4750b548ba81688c23 (diff) | |
| parent | 1d35dd8a80f0ea72306e96c2229a27798ec75ce9 (diff) | |
| download | which-ui-a6d2d1d833116772178125b3e047e0811131c0e0.tar.gz | |
Merge pull request #81 from which-ecosystem/better-ux
Handle empty states
Diffstat (limited to 'src/components')
| -rw-r--r-- | src/components/EmptyState/EmptyState.tsx | 58 | 
1 files changed, 58 insertions, 0 deletions
| diff --git a/src/components/EmptyState/EmptyState.tsx b/src/components/EmptyState/EmptyState.tsx new file mode 100644 index 0000000..214bb56 --- /dev/null +++ b/src/components/EmptyState/EmptyState.tsx @@ -0,0 +1,58 @@ +import React from 'react'; +import Typography from '@material-ui/core/Typography'; +import { makeStyles } from '@material-ui/core/styles'; +import noContentIcon from '../../assets/noContent.svg'; +import constructionIcon from '../../assets/construction.svg'; + + +interface PropTypes { +  variant?: 'default' | 'construction'; +  message?: string; +} + +const useStyles = makeStyles(theme => ({ +  root: { +    display: 'flex', +    flexDirection: 'column', +    justifyContent: 'center', +    alignItems: 'center' +  }, +  img: { +    margin: theme.spacing(2), +    width: theme.spacing(24) +  } + +})); + +const CONTEXT = { +  default: { +    icon: noContentIcon, +    tagline: 'No content' +  }, +  construction: { +    icon: constructionIcon, +    tagline: 'Coming soon' +  } +}; + +const EmptyState: React.FC<PropTypes> = ({ variant = 'default', message }) => { +  const classes = useStyles(); + +  const { icon, tagline } = CONTEXT[variant]; + +  return ( +    <div className={classes.root}> +      <img src={icon} className={classes.img} alt="No content" /> +      <Typography variant="h5"> +        {tagline} +      </Typography> +      <Typography color="textSecondary"> +        <p> +          {message} +        </p> +      </Typography> +    </div> +  ); +}; + +export default EmptyState; | 
