diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/components/Fab/Fab.tsx | 23 | ||||
| -rw-r--r-- | src/components/ModalScreen/ModalScreen.tsx | 80 | ||||
| -rw-r--r-- | src/containers/Page/Page.tsx | 13 | ||||
| -rw-r--r-- | src/containers/Page/Router.tsx | 48 | ||||
| -rw-r--r-- | src/containers/PollCreation/PollCreation.tsx | 60 | 
5 files changed, 159 insertions, 65 deletions
| diff --git a/src/components/Fab/Fab.tsx b/src/components/Fab/Fab.tsx index 7ca2893..f6b85e5 100644 --- a/src/components/Fab/Fab.tsx +++ b/src/components/Fab/Fab.tsx @@ -1,5 +1,5 @@  import React from 'react'; -import { useHistory } from 'react-router-dom'; +import { useLocation, Link } from 'react-router-dom';  import { Fab as FabBase, Slide, useScrollTrigger } from '@material-ui/core/';  import { makeStyles } from '@material-ui/core/styles';  import PlusIcon from '@material-ui/icons/Add'; @@ -26,22 +26,19 @@ const useStyles = makeStyles(theme => ({  const Fab: React.FC<PropTypes> = ({ hideOnScroll = false }) => {    const classes = useStyles(); -  const history = useHistory(); +  const location = useLocation();    const trigger = useScrollTrigger(); -  const handleClick = () => { -    history.push('/new'); -  }; -    return (      <Slide appear={false} direction="up" in={(!hideOnScroll) || !trigger}> -      <FabBase -        onClick={handleClick} -        className={classes.root} -        color="secondary" -      > -        <PlusIcon /> -      </FabBase> +      <Link to={{ pathname: '/new', state: { background: location } }}> +        <FabBase +          className={classes.root} +          color="secondary" +        > +          <PlusIcon /> +        </FabBase> +      </Link>      </Slide>    );  }; diff --git a/src/components/ModalScreen/ModalScreen.tsx b/src/components/ModalScreen/ModalScreen.tsx new file mode 100644 index 0000000..81e5c5a --- /dev/null +++ b/src/components/ModalScreen/ModalScreen.tsx @@ -0,0 +1,80 @@ +import React, { useState, useCallback } from 'react'; +import { useHistory } from 'react-router-dom'; +import { +  AppBar, +  Dialog, +  Toolbar, +  Typography, +  IconButton, +  Divider, +  Slide, +  useMediaQuery, +  useTheme +} from '@material-ui/core'; +import { makeStyles } from '@material-ui/core/styles'; +import CloseIcon from '@material-ui/icons/Close'; +import { TransitionProps } from '@material-ui/core/transitions'; + +interface PropTypes { +  title: string; +} + +const useStyles = makeStyles(theme => ({ +  root: { +    backgroundColor: theme.palette.background.default +  }, +  content: { +    padding: theme.spacing(3, 0, 0, 0) +  }, +  toolbar: { +    display: 'flex', +    justifyContent: 'space-between' +  } +})); + +const Transition = React.forwardRef(( +  props: TransitionProps & { children?: React.ReactElement }, +  ref: React.Ref<unknown> +) => <Slide direction="left" ref={ref} {...props} />); + +const ModalScreen: React.FC<PropTypes> = ({ title, children }) => { +  const [isOpen, setIsOpen] = useState<boolean>(true); +  const classes = useStyles(); +  const theme = useTheme(); +  const isMobile = useMediaQuery(theme.breakpoints.down('sm')); +  const history = useHistory(); + +  const handleClose = useCallback(() => setIsOpen(false), [setIsOpen]); +  const onExited = useCallback(() => history.goBack(), [history]); + +  return ( +    <Dialog +      open={isOpen} +      onExited={onExited} +      TransitionComponent={Transition} +      PaperProps={{ className: classes.root }} +      fullScreen={isMobile} +      fullWidth +    > +      <AppBar position="static"> +        <Toolbar className={classes.toolbar}> +          <IconButton onClick={handleClose}> +            <CloseIcon /> +          </IconButton> +          <Typography variant="h6"> +            { title } +          </Typography> +          <IconButton style={{ opacity: 0, pointerEvents: 'none' }}> +            <CloseIcon /> +          </IconButton> +        </Toolbar> +      </AppBar> +      <Divider /> +      <div className={classes.content}> +        { children } +      </div> +    </Dialog> +  ); +}; + +export default ModalScreen; diff --git a/src/containers/Page/Page.tsx b/src/containers/Page/Page.tsx index 7df62cd..b7e1938 100644 --- a/src/containers/Page/Page.tsx +++ b/src/containers/Page/Page.tsx @@ -5,11 +5,14 @@ import { SnackbarProvider } from 'notistack';  import { ErrorBoundary } from 'react-error-boundary';  import { useHistory } from 'react-router-dom'; -import Router from './Router'; +import Router, { LocationState } from './Router';  import DynoWaiter from './DynoWaiter';  import Loading from '../../components/Loading/Loading';  import EmptyState from '../../components/EmptyState/EmptyState'; +interface HistoryChange { +  state?: LocationState | null; +}  const useStyles = makeStyles(theme => ({    root: { @@ -32,11 +35,9 @@ const Page: React.FC = () => {    const history = useHistory();    const isMobile = useMediaQuery(theme.breakpoints.down('sm')); -  useEffect(() => { -    return history.listen(() => { -      window.scrollTo(0, 0); -    }); -  }, [history]); +  useEffect(() => history.listen((update: HistoryChange) => { +    if (!update.state?.background) window.scrollTo(0, 0); +  }), [history]);    return (      <SnackbarProvider diff --git a/src/containers/Page/Router.tsx b/src/containers/Page/Router.tsx index 7067eea..7c3a418 100644 --- a/src/containers/Page/Router.tsx +++ b/src/containers/Page/Router.tsx @@ -1,5 +1,8 @@  import React from 'react'; -import { Switch, Route } from 'react-router-dom'; +import { Switch, Route, useLocation } from 'react-router-dom'; +import { Location } from 'history'; + +import PollCreation from '../PollCreation/PollCreation';  const Profile = React.lazy(() => import('../Profile/Profile'));  const Feed = React.lazy(() => import('../Feed/Feed')); @@ -7,20 +10,35 @@ const Login = React.lazy(() => import('../Login/Login'));  const Registration = React.lazy(() => import('../Registration/Registration'));  const Home = React.lazy(() => import('../Home/Home'));  const Notifications = React.lazy(() => import('../Notifications/Notifications')); -const PollCreation = React.lazy(() => import('../PollCreation/PollCreation')); - - -const Router: React.FC = React.memo(() => ( -  <Switch> -    <Route exact path="/" component={Home} /> -    <Route exact path="/login" component={Login} /> -    <Route exact path="/registration" component={Registration} /> -    <Route exact path="/feed" component={Feed} /> -    <Route exact path="/notifications" component={Notifications} /> -    <Route exact path="/new" component={PollCreation} /> -    <Route path="/profile/:username" component={Profile} /> -  </Switch> -)); + +export interface LocationState { +  background?: Location; +} + +const Router: React.FC = React.memo(() => { +  const location = useLocation<LocationState>(); +  const background = location.state && location.state.background; + +  const ModalSwitch = ( +    <Switch> +      <Route path="/new" component={PollCreation} /> +    </Switch> +  ); + +  return ( +    <> +      {ModalSwitch} +      <Switch location={background || location}> +        <Route exact path="/" component={Home} /> +        <Route exact path="/login" component={Login} /> +        <Route exact path="/registration" component={Registration} /> +        <Route exact path="/notifications" component={Notifications} /> +        <Route path="/feed" component={Feed} /> +        <Route path="/profile/:username" component={Profile} /> +      </Switch> +    </> +  ); +});  export default Router; diff --git a/src/containers/PollCreation/PollCreation.tsx b/src/containers/PollCreation/PollCreation.tsx index ecc6757..b7ee00a 100644 --- a/src/containers/PollCreation/PollCreation.tsx +++ b/src/containers/PollCreation/PollCreation.tsx @@ -5,7 +5,6 @@ import { makeStyles } from '@material-ui/core/styles';  import {    Button,    Card, -  Divider,    Container,    LinearProgress  } from '@material-ui/core'; @@ -13,16 +12,14 @@ import { useSnackbar } from 'notistack';  import useS3Preupload from './useS3Preupload';  import ImageInput from './ImageInput'; +import ModalScreen from '../../components/ModalScreen/ModalScreen';  import UserStrip from '../../components/UserStrip/UserStrip';  import { post } from '../../requests'; -import { useAuth } from '../../hooks/useAuth';  import { useFeed } from '../../hooks/APIClient'; +import { useAuth } from '../../hooks/useAuth';  const useStyles = makeStyles(theme => ({ -  root: { -    marginBottom: theme.spacing(4) -  },    images: {      height: theme.spacing(50),      display: 'flex' @@ -33,8 +30,8 @@ const useStyles = makeStyles(theme => ({  const PollCreation: React.FC = () => {    const classes = useStyles();    const history = useHistory(); -  const { enqueueSnackbar } = useSnackbar();    const { user } = useAuth(); +  const { enqueueSnackbar } = useSnackbar();    const { mutate: updateFeed } = useFeed();    const {      file: left, @@ -71,31 +68,32 @@ const PollCreation: React.FC = () => {    };    return ( -    <Container maxWidth="sm" disableGutters> -      <Card className={classes.root}> -        {user && <UserStrip user={user} info="" />} -        <Divider /> -        <div className={classes.images}> -          <ImageInput callback={setLeft} progress={leftProgress} /> -          <ImageInput callback={setRight} progress={rightProgress} /> -        </div> -        { -          leftProgress || rightProgress -            ? <LinearProgress color="primary" /> -            : ( -              <Button -                color="primary" -                disabled={!(left && right)} -                variant="contained" -                onClick={handleClick} -                fullWidth -              > -                Submit -              </Button> -            ) -        } -      </Card> -    </Container> +    <ModalScreen title="Create a poll"> +      <Container maxWidth="sm" disableGutters> +        <Card elevation={3}> +          {user && <UserStrip user={user} info="" />} +          <div className={classes.images}> +            <ImageInput callback={setLeft} progress={leftProgress} /> +            <ImageInput callback={setRight} progress={rightProgress} /> +          </div> +          { +            leftProgress || rightProgress +              ? <LinearProgress color="primary" /> +              : ( +                <Button +                  color="primary" +                  disabled={!(left && right)} +                  variant="contained" +                  onClick={handleClick} +                  fullWidth +                > +                  Submit +                </Button> +              ) +          } +        </Card> +      </Container> +    </ModalScreen>    );  }; | 
