From 98b41f315f1b8a564deed4549c2589b90ffdfa81 Mon Sep 17 00:00:00 2001 From: Maciej Stosio Date: Tue, 14 Jan 2025 19:27:38 +0100 Subject: [PATCH 1/3] fix: dimensionbox size --- .../src/webview/components/DimensionsBox.css | 12 ++++--- .../src/webview/components/DimensionsBox.tsx | 32 +++++++------------ 2 files changed, 18 insertions(+), 26 deletions(-) diff --git a/packages/vscode-extension/src/webview/components/DimensionsBox.css b/packages/vscode-extension/src/webview/components/DimensionsBox.css index 19db2bf19..65b3b984b 100644 --- a/packages/vscode-extension/src/webview/components/DimensionsBox.css +++ b/packages/vscode-extension/src/webview/components/DimensionsBox.css @@ -3,15 +3,16 @@ position: absolute; left: var(--left); top: var(--top); - height: var(--box-height); - font-size: var(--font-size); - border-radius: var(--border-radius); - padding-left: var(--horizontal-padding); - padding-right: var(--horizontal-padding); + height: 18px; + font-size: 10px; + border-radius: 4px; + padding-left: 8px; + padding-right: 8px; display: flex; align-items: center; white-space: nowrap; transform: var(--box-transform); + margin: var(--margin); } .arrow { @@ -23,4 +24,5 @@ height: var(--arrow-size); transform-origin: 50% 50%; transform: translate(-50%, -50%) rotate(45deg); + margin: var(--margin); } diff --git a/packages/vscode-extension/src/webview/components/DimensionsBox.tsx b/packages/vscode-extension/src/webview/components/DimensionsBox.tsx index 0c0736589..d80e3350d 100644 --- a/packages/vscode-extension/src/webview/components/DimensionsBox.tsx +++ b/packages/vscode-extension/src/webview/components/DimensionsBox.tsx @@ -2,17 +2,10 @@ import { Frame } from "../../common/Project"; import { DeviceProperties } from "../utilities/consts"; import "./DimensionsBox.css"; -const BOX_HEIGHT_FRACTION = 0.033; -const FONT_SIZE_FRACTION = 0.6; -const BORDER_RADIUS_FRACTION = 0.15; -const HORIZONTAL_PADDING_FRACTION = 0.3; -const ARROW_SIZE_FRACTION = 0.4; - const VERTICAL_POSITION_THRESHOLD = 0.3; const HORIZONTAL_POSITION_THRESHOLD = 0.5; -const VERTICAL_ARROW_MARGIN = 0.015; -const HORIZONTAL_ARROW_MARGIN = 0.03; +const ARROW_SIZE = 8; type DimensionsBoxProps = { device?: DeviceProperties; @@ -41,8 +34,6 @@ function DimensionsBox({ device, frame, wrapperDivRef }: DimensionsBoxProps) { return; } - const { clientHeight: previewHeight } = previewDiv; - const boxPosition: DimensionsBoxPosition = (() => { if (frame.y >= VERTICAL_POSITION_THRESHOLD) { return "above"; @@ -60,45 +51,44 @@ function DimensionsBox({ device, frame, wrapperDivRef }: DimensionsBoxProps) { switch (boxPosition) { case "above": return { - "--top": `${(frame.y - VERTICAL_ARROW_MARGIN) * 100}%`, + "--top": `${(frame.y) * 100}%`, "--left": `${(frame.x + frame.width / 2) * 100}%`, "--box-transform": "translate(-50%, -100%)", + "--margin": `-${ARROW_SIZE/2}px 0 0 0`, }; case "below": return { - "--top": `${(frame.y + frame.height + VERTICAL_ARROW_MARGIN) * 100}%`, + "--top": `${(frame.y + frame.height) * 100}%`, "--left": `${(frame.x + frame.width / 2) * 100}%`, "--box-transform": "translate(-50%, 0%)", + "--margin": `${ARROW_SIZE/2}px 0 0 0`, }; case "right": return { "--top": `${(frame.y + frame.height / 2) * 100}%`, - "--left": `${(frame.x + frame.width + HORIZONTAL_ARROW_MARGIN) * 100}%`, + "--left": `${(frame.x + frame.width) * 100}%`, "--box-transform": "translate(0%, -50%)", + "--margin": `0 0 0 ${ARROW_SIZE/2}px`, }; case "left": return { "--top": `${(frame.y + frame.height / 2) * 100}%`, - "--left": `${(frame.x - HORIZONTAL_ARROW_MARGIN) * 100}%`, + "--left": `${frame.x * 100}%`, "--box-transform": "translate(-100%, -50%)", + "--margin": `0 0 0 -${ARROW_SIZE/2}px`, }; default: return { "--top": `${(frame.y + frame.height / 2) * 100}%`, "--left": `${(frame.x + frame.width / 2) * 100}%`, "--box-transform": "translate(-50%, -50%)", + "--margin": `0 0 0 0`, }; } })(); - const boxHeight = previewHeight * BOX_HEIGHT_FRACTION; - const cssPropertiesForDimensionsBox = { - "--box-height": `${boxHeight}px`, - "--font-size": `${boxHeight * FONT_SIZE_FRACTION}px`, - "--border-radius": `${boxHeight * BORDER_RADIUS_FRACTION}px`, - "--horizontal-padding": `${boxHeight * HORIZONTAL_PADDING_FRACTION}px`, - "--arrow-size": `${boxHeight * ARROW_SIZE_FRACTION}px`, + "--arrow-size": `${ARROW_SIZE}px`, ...positionalProps, }; From e8a98bad318d1532f6231a5429f2eb07a106324e Mon Sep 17 00:00:00 2001 From: Maciej Stosio Date: Tue, 14 Jan 2025 19:34:55 +0100 Subject: [PATCH 2/3] fix: add spacing --- .../src/webview/components/DimensionsBox.tsx | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/packages/vscode-extension/src/webview/components/DimensionsBox.tsx b/packages/vscode-extension/src/webview/components/DimensionsBox.tsx index d80e3350d..3615aafbb 100644 --- a/packages/vscode-extension/src/webview/components/DimensionsBox.tsx +++ b/packages/vscode-extension/src/webview/components/DimensionsBox.tsx @@ -54,28 +54,28 @@ function DimensionsBox({ device, frame, wrapperDivRef }: DimensionsBoxProps) { "--top": `${(frame.y) * 100}%`, "--left": `${(frame.x + frame.width / 2) * 100}%`, "--box-transform": "translate(-50%, -100%)", - "--margin": `-${ARROW_SIZE/2}px 0 0 0`, + "--margin": `-${ARROW_SIZE}px 0 0 0`, }; case "below": return { "--top": `${(frame.y + frame.height) * 100}%`, "--left": `${(frame.x + frame.width / 2) * 100}%`, "--box-transform": "translate(-50%, 0%)", - "--margin": `${ARROW_SIZE/2}px 0 0 0`, + "--margin": `${ARROW_SIZE}px 0 0 0`, }; case "right": return { "--top": `${(frame.y + frame.height / 2) * 100}%`, "--left": `${(frame.x + frame.width) * 100}%`, "--box-transform": "translate(0%, -50%)", - "--margin": `0 0 0 ${ARROW_SIZE/2}px`, + "--margin": `0 0 0 ${ARROW_SIZE}px`, }; case "left": return { "--top": `${(frame.y + frame.height / 2) * 100}%`, "--left": `${frame.x * 100}%`, "--box-transform": "translate(-100%, -50%)", - "--margin": `0 0 0 -${ARROW_SIZE/2}px`, + "--margin": `0 0 0 -${ARROW_SIZE}px`, }; default: return { From 79c2239c4941464c94c5a5fab8de5f71376a62b1 Mon Sep 17 00:00:00 2001 From: Maciej Stosio Date: Tue, 14 Jan 2025 19:35:22 +0100 Subject: [PATCH 3/3] fix lint --- .../vscode-extension/src/webview/components/DimensionsBox.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/vscode-extension/src/webview/components/DimensionsBox.tsx b/packages/vscode-extension/src/webview/components/DimensionsBox.tsx index 3615aafbb..4038b9fb3 100644 --- a/packages/vscode-extension/src/webview/components/DimensionsBox.tsx +++ b/packages/vscode-extension/src/webview/components/DimensionsBox.tsx @@ -51,7 +51,7 @@ function DimensionsBox({ device, frame, wrapperDivRef }: DimensionsBoxProps) { switch (boxPosition) { case "above": return { - "--top": `${(frame.y) * 100}%`, + "--top": `${frame.y * 100}%`, "--left": `${(frame.x + frame.width / 2) * 100}%`, "--box-transform": "translate(-50%, -100%)", "--margin": `-${ARROW_SIZE}px 0 0 0`,