Calculate HoverPreview position inside useLayoutEffect (#5636)

This commit is contained in:
Apoorv Mishra
2023-08-06 21:30:05 +05:30
committed by GitHub
parent 6c4e2a9d11
commit 0ddbd9c608
5 changed files with 97 additions and 74 deletions

View File

@@ -4,11 +4,7 @@ import styled, { css } from "styled-components";
import { s } from "@shared/styles";
import Text from "~/components/Text";
export const CARD_PADDING = 16;
export const CARD_WIDTH = 375;
export const THUMBNAIL_HEIGHT = 200;
export const CARD_MARGIN = 16;
const NUMBER_OF_LINES = 10;
@@ -28,6 +24,8 @@ export const Preview = styled(Link)`
0 0 1px 1px rgba(0, 0, 0, 0.05);
overflow: hidden;
position: absolute;
min-width: 350px;
max-width: 375px;
`;
export const Title = styled.h2`
@@ -39,7 +37,9 @@ export const Title = styled.h2`
export const Info = styled(StyledText).attrs(() => ({
type: "tertiary",
size: "xsmall",
}))``;
}))`
white-space: nowrap;
`;
export const Description = styled(StyledText)`
${sharedVars}
@@ -48,6 +48,12 @@ export const Description = styled(StyledText)`
max-height: calc(var(--line-height) * ${NUMBER_OF_LINES});
`;
export const Thumbnail = styled.img`
object-fit: cover;
height: 200px;
background: ${s("menuBackground")};
`;
export const CardContent = styled.div`
overflow: hidden;
user-select: none;
@@ -57,8 +63,7 @@ export const CardContent = styled.div`
export const Card = styled.div<{ fadeOut?: boolean; $borderRadius?: string }>`
backdrop-filter: blur(10px);
background: ${s("menuBackground")};
padding: ${CARD_PADDING}px;
width: ${CARD_WIDTH}px;
padding: 16px;
font-size: 0.9em;
position: relative;