From 1392d8f8283f80cbdbe11d81648882faa6a2ef22 Mon Sep 17 00:00:00 2001 From: Kenny Jung Date: Sun, 8 Aug 2021 17:37:38 -0400 Subject: [PATCH 1/2] feat: improve consistency between Tree Detail and Planter Detail dialogs #10 --- src/components/CaptureDetailDialog.js | 129 +++++++++++++++++--------- 1 file changed, 83 insertions(+), 46 deletions(-) diff --git a/src/components/CaptureDetailDialog.js b/src/components/CaptureDetailDialog.js index 266442341..0381b2495 100644 --- a/src/components/CaptureDetailDialog.js +++ b/src/components/CaptureDetailDialog.js @@ -1,4 +1,4 @@ -import React, { Fragment, useRef, useState, useEffect } from 'react'; +import React, { Fragment, useCallback, useState, useEffect } from 'react'; import compose from 'recompose/compose'; import { connect } from 'react-redux'; @@ -6,14 +6,14 @@ import { connect } from 'react-redux'; import { makeStyles } from '@material-ui/core/styles'; import Typography from '@material-ui/core/Typography'; import Dialog from '@material-ui/core/Dialog'; -import DialogActions from '@material-ui/core/DialogActions'; -import DialogContent from '@material-ui/core/DialogContent'; import Grid from '@material-ui/core/Grid'; import Divider from '@material-ui/core/Divider'; import Chip from '@material-ui/core/Chip'; -import Button from '@material-ui/core/Button'; import IconButton from '@material-ui/core/IconButton'; import Snackbar from '@material-ui/core/Snackbar'; +import Drawer from '@material-ui/core/Drawer'; +import Box from '@material-ui/core/Box'; +import Close from '@material-ui/icons/Close'; import FileCopy from '@material-ui/icons/FileCopy'; import CloseIcon from '@material-ui/icons/Close'; @@ -57,6 +57,22 @@ const useStyles = makeStyles((theme) => ({ fontSize: '0.8em', color: 'rgba(0,0,0,0.5)', }, + root: { + width: 340, + }, + drawer: { + width: 0, + // remove backdrop + '& .MuiBackdrop-root': { + display: 'none', + }, + }, + dialog: { + backgroundColor: 'rgba(0, 0, 0, 0.75)', + }, + box: { + padding: theme.spacing(4), + }, })); function CaptureDetailDialog(props) { @@ -65,12 +81,20 @@ function CaptureDetailDialog(props) { const [snackbarOpen, setSnackbarOpen] = useState(false); const [snackbarLabel, setSnackbarLabel] = useState(''); const [renderCapture, setRenderCapture] = useState(capture); + const [screenWidth, setScreenWidth] = useState(window.innerWidth); + const resizeWidth = useCallback(() => { + setScreenWidth(window.innerWidth); + }, []); const classes = useStyles(); - const textAreaRef = useRef(null); useEffect(() => { props.captureDetailDispatch.getCaptureDetail(props.capture.id); - }, [props.captureDetailDispatch, props.capture]); + + window.addEventListener('resize', resizeWidth); + return () => { + window.removeEventListener('resize', resizeWidth); + }; + }, [props.captureDetailDispatch, props.capture, resizeWidth]); /* * Render the most complete capture detail we have @@ -132,15 +156,26 @@ function CaptureDetailDialog(props) { } return ( - + - - Capture - - + + + + + Capture + + + + + + props.onClose()}> + + + + - + Capture Data {[ { @@ -180,7 +215,7 @@ function CaptureDetailDialog(props) { ))} - + Verification Status @@ -202,7 +237,7 @@ function CaptureDetailDialog(props) { )} - + Tags Species {species && species.name ? ( @@ -227,7 +262,7 @@ function CaptureDetailDialog(props) { )} - + Capture Token {getTokenStatus(capture.tokenId)} @@ -261,40 +296,42 @@ function CaptureDetailDialog(props) { } return ( - - - - - + + + + + + + - - - - - - - - - -