From 077a3aad3b623433ff4903caf014b926fea72c69 Mon Sep 17 00:00:00 2001 From: Simon Larsen Date: Fri, 1 Nov 2024 16:55:17 +0000 Subject: [PATCH] Refactor DashboardBaseComponent to improve coordinate calculation and ensure new positions remain within dashboard bounds --- .../Components/DashboardBaseComponent.tsx | 35 ++++++++++++------- 1 file changed, 22 insertions(+), 13 deletions(-) diff --git a/Dashboard/src/Components/Dashboard/Components/DashboardBaseComponent.tsx b/Dashboard/src/Components/Dashboard/Components/DashboardBaseComponent.tsx index 27b01eccbbc..8df54a4daba 100644 --- a/Dashboard/src/Components/Dashboard/Components/DashboardBaseComponent.tsx +++ b/Dashboard/src/Components/Dashboard/Components/DashboardBaseComponent.tsx @@ -73,27 +73,35 @@ const DashboardBaseComponentElement: FunctionComponent = ( const newMoveToTop: number = mouseEvent.pageY; const newMoveToLeft: number = mouseEvent.pageX; - const oldTopDashboardUnits: number = props.component.topInDashboardUnits + 1; - const oldLeftDashboardUnits: number = props.component.leftInDashboardUnits + 1; + const deltaXInPx: number = newMoveToLeft - dashboardComponentOldLeftInPx; + const deltaYInPx: number = newMoveToTop - dashboardComponentOldTopInPx; - // calculare new top and new left. - let newTopInDashboardUnits: number = Math.floor( - (newMoveToTop * oldTopDashboardUnits) / dashboardComponentOldTopInPx, - ) - 1; - let newLeftInDashboardUnits: number = Math.floor( - (newMoveToLeft * oldLeftDashboardUnits) / dashboardComponentOldLeftInPx, - ) - 1; + const eachDashboardUnitInPx: number = GetDashboardUnitWidthInPx( + props.totalCurrentDashboardWidthInPx, + ); + + const deltaXInDashboardUnits: number = Math.round( + deltaXInPx / eachDashboardUnitInPx, + ); + const deltaYInDashboardUnits: number = Math.round( + deltaYInPx / eachDashboardUnitInPx, + ); - // check if the new top and left are within the bounds of the dashboard + let newTopInDashboardUnits: number = + props.component.topInDashboardUnits + deltaYInDashboardUnits; + let newLeftInDashboardUnits: number = + props.component.leftInDashboardUnits + deltaXInDashboardUnits; + + // now make sure these are within the bounds of the dashboard inch component width and height in dashbosrd units const dahsboardTotalWidthInDashboardUnits: number = DefaultDashboardSize.widthInDashboardUnits; // width does not change - const dashboardTotalHeightInDashboardUnits: number = props.dashboardViewConfig.heightInDashboardUnits; const heightOfTheComponntInDashboardUnits: number = props.component.heightInDashboardUnits; + const widthOfTheComponentInDashboardUnits: number = props.component.widthInDashboardUnits; @@ -117,12 +125,13 @@ const DashboardBaseComponentElement: FunctionComponent = ( widthOfTheComponentInDashboardUnits; } + // make sure they are not negative - if(newTopInDashboardUnits < 0) { + if (newTopInDashboardUnits < 0) { newTopInDashboardUnits = 0; } - if(newLeftInDashboardUnits < 0) { + if (newLeftInDashboardUnits < 0) { newLeftInDashboardUnits = 0; }