Skip to content

Commit

Permalink
Replace Stock Details dialog with link to Stock Details page (#1306)
Browse files Browse the repository at this point in the history
* Allow lazy loading for avatars in lists

Signed-off-by: Marvin A. Ruder <[email protected]>
  • Loading branch information
marvinruder authored May 18, 2024
1 parent 7f9f045 commit c5c86c6
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 73 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ export const StockPreview = ({ stock, navLink, onDelete, ...props }: StockPrevie
}`
}
alt={`Logo of “${stock.name}”`}
slotProps={{ img: { loading: "lazy" } }}
/>
</ListItemAvatar>
<ListItemText primary={stock.name} primaryTypographyProps={{ fontWeight: "bold" }} secondary={stock.ticker} />
Expand Down
84 changes: 11 additions & 73 deletions packages/frontend/src/components/stock/layouts/StockRow.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ import AddShoppingCartIcon from "@mui/icons-material/AddShoppingCart";
import ArrowDropDownIcon from "@mui/icons-material/ArrowDropDown";
import BookmarkAddIcon from "@mui/icons-material/BookmarkAdd";
import BookmarkRemoveIcon from "@mui/icons-material/BookmarkRemove";
import CloseIcon from "@mui/icons-material/Close";
import DeleteIcon from "@mui/icons-material/Delete";
import EditIcon from "@mui/icons-material/Edit";
import NaturePeopleIcon from "@mui/icons-material/NaturePeople";
Expand All @@ -15,32 +14,26 @@ import StarOutlineIcon from "@mui/icons-material/StarOutline";
import StarsIcon from "@mui/icons-material/Stars";
import ThermostatIcon from "@mui/icons-material/Thermostat";
import VerifiedIcon from "@mui/icons-material/Verified";
import type { SlideProps } from "@mui/material";
import {
Avatar,
Badge,
Box,
Chip,
darken,
Dialog,
DialogContent,
DialogTitle,
Divider,
Grid,
IconButton,
InputAdornment,
Link,
ListItemIcon,
ListItemText,
Menu,
MenuItem,
Skeleton,
Slide,
TableCell,
TableRow,
TextField,
Tooltip,
Typography,
useMediaQuery,
useTheme,
} from "@mui/material";
import type {
Expand Down Expand Up @@ -107,8 +100,6 @@ import { SectorIcon } from "../properties/SectorIcon";
import { StarRating } from "../properties/StarRating";
import { StyleBox } from "../properties/StyleBox";

import { StockDetails } from "./StockDetails";

/**
* This component displays information about a stock in a table row that is used in the stock list.
* @param props The properties of the component.
Expand All @@ -128,7 +119,6 @@ export const StockRow = (props: StockRowProps): JSX.Element => {

const [optionsMenuOpen, setOptionsMenuOpen] = useState<boolean>(false);
const [optionsMenuPositionEvent, setOptionsMenuPositionEvent] = useState<React.MouseEvent<HTMLElement, MouseEvent>>();
const [detailsDialogOpen, setDetailsDialogOpen] = useState<boolean>(false);
const [editDialogOpen, setEditDialogOpen] = useState<boolean>(false);
const [deleteDialogOpen, setDeleteDialogOpen] = useState<boolean>(false);
const [addToWatchlistDialogOpen, setAddToWatchlistDialogOpen] = useState<boolean>(false);
Expand Down Expand Up @@ -168,8 +158,6 @@ export const StockRow = (props: StockRowProps): JSX.Element => {
.catch((e) => setErrorNotificationOrClearSession(e, "editing stock in portfolio"));
};

const fullScreenDialogs = !useMediaQuery("(min-width:664px)");

const contextMenuPositionRef = useRef<HTMLElement>(null);
const updateAmountButtonRef = useRef<HTMLButtonElement>(null);
const infiniteLoadingTriggerRef = useRef<HTMLTableRowElement>(null);
Expand Down Expand Up @@ -221,8 +209,7 @@ export const StockRow = (props: StockRowProps): JSX.Element => {
!addToPortfolioDialogOpen &&
!removeFromPortfolioDialogOpen &&
!editDialogOpen &&
!deleteDialogOpen &&
!detailsDialogOpen
!deleteDialogOpen
) {
e.preventDefault();
if (optionsMenuOpen) {
Expand Down Expand Up @@ -448,13 +435,13 @@ export const StockRow = (props: StockRowProps): JSX.Element => {
)}
{/* Name and Logo */}
<TableCell>
<Box
onClick={() => setDetailsDialogOpen(true)}
sx={{
display: "flex",
alignItems: "center",
cursor: "pointer",
}}
<Link
component={NavLink}
to={`${stocksAPIPath}/${props.stock.ticker}`}
target="_blank"
color="inherit"
underline="none"
sx={{ display: "flex", alignItems: "center" }}
>
<Badge
anchorOrigin={{ vertical: "top", horizontal: "left" }}
Expand All @@ -473,6 +460,7 @@ export const StockRow = (props: StockRowProps): JSX.Element => {
theme.palette.mode === "dark"
}`}
alt={`Logo of “${props.stock.name}”`}
slotProps={{ img: { loading: "lazy" } }}
/>
</Badge>
<Box width={8} />
Expand All @@ -484,7 +472,7 @@ export const StockRow = (props: StockRowProps): JSX.Element => {
{props.stock.ticker} | {props.stock.isin}
</Typography>
</Box>
</Box>
</Link>
</TableCell>
{/* Country and Region */}
<TableCell sx={{ display: displayColumn("Country") }}>
Expand Down Expand Up @@ -813,56 +801,6 @@ export const StockRow = (props: StockRowProps): JSX.Element => {
<Box sx={{ float: "right" }}>{props.stock.marketCap !== null ? formatMarketCap(props.stock) : "–"}</Box>
</Typography>
</TableCell>
{/* Details Dialog */}
<Dialog
open={detailsDialogOpen}
onClose={() => setDetailsDialogOpen(false)}
maxWidth="md"
fullScreen={fullScreenDialogs}
TransitionComponent={fullScreenDialogs ? Slide : undefined}
TransitionProps={{ direction: "up" } as SlideProps}
>
<DialogTitle>
<Grid container justifyContent="space-between">
<Grid item display="flex" alignItems="center" maxWidth="calc(100% - 40px)">
<Avatar
sx={{
width: 112,
height: 112,
m: "-16px",
mr: "-8px",
background: "none",
}}
src={`${baseURL}${stocksAPIPath}/${props.stock.ticker}${stockLogoEndpointSuffix}?dark=${
theme.palette.mode === "dark"
}`}
alt={`Logo of “${props.stock.name}”`}
/>
<Box sx={{ my: 1 }}>
<Typography variant="h4" gutterBottom>
{props.stock.name}
</Typography>
<Typography variant="subtitle2">
{props.stock.ticker} | {props.stock.isin}
</Typography>
</Box>
</Grid>
<Grid item>
<IconButton
aria-label={`Close details dialog of “${props.stock.name}”`}
onClick={() => setDetailsDialogOpen(false)}
sx={{ borderRadius: 20 }}
>
<CloseIcon />
</IconButton>
</Grid>
</Grid>
</DialogTitle>
<Divider />
<DialogContent sx={{ p: 0, pb: 1 }}>
<StockDetails stock={props.stock} />
</DialogContent>
</Dialog>
{/* Edit Dialog */}
<Dialog open={editDialogOpen}>
<EditStock stock={props.stock} onCloseAfterEdit={props.getStocks} onClose={() => setEditDialogOpen(false)} />
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,7 @@ const UserRow = (props: UserRowProps): JSX.Element => {
sx={{ width: 64, height: 64, m: "4px", background: "none" }}
src={props.user.avatar}
alt={props.user.name}
slotProps={{ img: { loading: "lazy" } }}
/>
<Box width={8} />
<Box>
Expand Down

0 comments on commit c5c86c6

Please sign in to comment.