civictechindex/CTI-website-frontend

View on GitHub
src/components/PictureCard.js

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
import React from "react";
import Grid from "@material-ui/core/Grid";
import Box from '@material-ui/core/Box'
import Container from '@material-ui/core/Container';
import { Typography } from "@material-ui/core";
import { makeStyles } from '@material-ui/core/styles'

const useStyles = makeStyles((theme) => ({
  textStyle:{
    textAlign:'left',
    [theme.breakpoints.down('md')]: {
      fontSize: '1.25rem',
      textAlign:'center',
    },
  },
  item1_img: {
    margin:'auto',
    order:1,
  },
  item1_txt: {
    margin:'auto',
    order:2,
  },
  item2_img: {
    margin:'auto',
    order:3,
    [theme.breakpoints.up('lg')]: {
      order: 4,
    },
  },
  item2_txt: {
    margin:'auto',
    order:4,
    [theme.breakpoints.up('lg')]: {
      order: 3,
    },
  },
  item3_img: {
    margin:'auto',
    order:5,
  },
  item3_txt: {
    margin:'auto',
    order:6,
  },
}))


/**
 * Generates marketing cards that contain an image and text. 3 part grid containing multiple card items.
 * @param {*} props.imgSrc
 * @param {*} props.imgAlt
 * @param {*} props.children
 */
export default function PictureCard(props) {
  const items = props.items;
  const classes = useStyles()

  return (
    <>
      <Box className='containerGray' pt='30px' pb='115px'>
        <Container>
          <Grid container display='flex' justify='flex-start'>
            <Grid
              item
              xs={8}
              md={8}
              lg={5}
              align='center'
              className={classes.item1_img}
            >
              <img src={items[0].src} alt={items[0].alt} />
            </Grid>
            <Grid item xs={8} md={8} lg={5} className={classes.item1_txt}>
              <Typography
                variant='h4'
                aria-level='2'
                className={classes.textStyle}
              >
                {items[0].children}
              </Typography>
            </Grid>
            <Grid
              item
              xs={8}
              md={8}
              lg={5}
              align='center'
              className={classes.item2_img}
            >
              <img src={items[1].src} alt={items[1].alt} />
            </Grid>
            <Grid item xs={8} md={8} lg={5} className={classes.item2_txt}>
              <Typography
                variant='h4'
                aria-level='2'
                className={classes.textStyle}
              >
                {items[1].children}
              </Typography>
            </Grid>
            <Grid
              item
              xs={8}
              md={8}
              lg={5}
              align='center'
              className={classes.item3_img}
            >
              <img src={items[2].src} alt={items[2].alt} />
            </Grid>
            <Grid item xs={8} md={8} lg={5} className={classes.item3_txt}>
              <Typography
                variant='h4'
                aria-level='2'
                className={classes.textStyle}
              >
                {items[2].children}
              </Typography>
            </Grid>
          </Grid>
        </Container>
      </Box>
    </>
  );
}