Skip to content

Commit

Permalink
handle overflow within drawCreateOutcomeConnection
Browse files Browse the repository at this point in the history
  • Loading branch information
Connoropolous committed Dec 27, 2023
1 parent d32d434 commit 69f97e7
Show file tree
Hide file tree
Showing 6 changed files with 52 additions and 65 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -189,7 +189,6 @@ const MapViewCreateOutcome: React.FC<MapViewCreateOutcomeProps> = ({
translate,
scale
)

// set card width in pixels
const cardWidth = 384
// use this hook to make sure the card is contained within the screen
Expand All @@ -209,7 +208,9 @@ const MapViewCreateOutcome: React.FC<MapViewCreateOutcomeProps> = ({
const height = outerRef.current.offsetHeight
setCardHeight(height)
}
}, [outerRef.current])
// this also fires when the `content` changes
// so that adjustments can be made to the height
}, [outerRef.current, content])

// focus text area
// after the whole thing becomes visible
Expand Down
2 changes: 1 addition & 1 deletion web/src/drawing/dimensions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -338,9 +338,9 @@ export function getOutcomeHeight({

const heightOfStatement = drawStatement(
argsForDrawStatement({
onlyMeasure: true, // we don't want it actually drawn on the canvas
useLineLimit,
noStatementPlaceholder,
onlyMeasure: true, // we don't want it actually drawn on the canvas
outcome,
outcomeLeftX: 0, // this number doesn't matter for measuring
outcomeTopY: 0, // this number doesn't matter for measuring
Expand Down
65 changes: 34 additions & 31 deletions web/src/drawing/drawCreateOutcomeConnection.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { RenderProps } from '../routes/ProjectView/MapView/selectRenderProps'
import { coordsCanvasToPage, coordsPageToCanvas } from './coordinateSystems'
import { getOutcomeWidth, getOutcomeHeight } from './dimensions'
import drawConnection, {
calculateConnectionCoordsByOutcomeCoords,
Expand All @@ -14,59 +15,61 @@ export default function drawCreateOutcomeConnection({
ctx,
coordinates,
allOutcomeDimensions,
projectTags,
zoomLevel,
translate,
outcomeFormMaybeLinkedOutcome,
outcomeFormContent,
outcomeFormLeftConnectionX,
outcomeFormTopConnectionY,
}: {
ctx: CanvasRenderingContext2D
coordinates: RenderProps['coordinates']
allOutcomeDimensions: RenderProps['dimensions']
projectTags: RenderProps['projectTags']
zoomLevel: RenderProps['zoomLevel']
translate: RenderProps['translate']
outcomeFormMaybeLinkedOutcome: RenderProps['outcomeFormMaybeLinkedOutcome']
outcomeFormContent: RenderProps['outcomeFormContent']
outcomeFormLeftConnectionX: RenderProps['outcomeFormLeftConnectionX']
outcomeFormTopConnectionY: RenderProps['outcomeFormTopConnectionY']
}) {
/*
establish width and height for the card for a
new Outcome in the process of being created
*/
const placeholderOutcomeWithText = getPlaceholderOutcome(outcomeFormContent)
const newOutcomeWidth = getOutcomeWidth({
outcome: placeholderOutcomeWithText,
zoomLevel,
})
const newOutcomeHeight = getOutcomeHeight({
ctx,
outcome: placeholderOutcomeWithText,
projectTags,
width: newOutcomeWidth,
zoomLevel,
// we set this because in the case of creating a new outcome
// it should use the full text at the proper text scaling
noStatementPlaceholder: true,
useLineLimit: false,
})
const outcomeFormFromActionHash =
outcomeFormMaybeLinkedOutcome.outcomeActionHash
const outcomeFormRelation = outcomeFormMaybeLinkedOutcome.relation
const sourceCoordinates = coordinates[outcomeFormFromActionHash]
const sourceDimensions = allOutcomeDimensions[outcomeFormFromActionHash]
const destinationCoordinates = {
x: outcomeFormLeftConnectionX,
y: outcomeFormTopConnectionY,
}
const pixelWidth = 384
const pixelHeight = 205
const destinationPageCoords = coordsCanvasToPage(destinationCoordinates, translate, zoomLevel)
// overflowX situation
if (destinationPageCoords.x + pixelWidth > window.innerWidth) {
const adjustBy = destinationPageCoords.x + pixelWidth - window.innerWidth
destinationCoordinates.x -= coordsPageToCanvas({ x: adjustBy, y: 0 }, { x: 0, y: 0 }, zoomLevel).x
}
// overflowY situation
if (destinationPageCoords.y + pixelHeight > window.innerHeight) {
const adjustBy = destinationPageCoords.y + pixelHeight - window.innerHeight
destinationCoordinates.y -= coordsPageToCanvas({ x: 0, y: adjustBy }, { x: 0, y: 0 }, zoomLevel).y
}
// convert the height of the card which is measured in pixels into
// the height of the card measured in canvas units
const createOutcomeCardCanvasWidthAndHeight = coordsPageToCanvas({ x: pixelWidth, y: pixelHeight }, { x: 0, y: 0 }, zoomLevel)
const destinationDimensions = {
width: createOutcomeCardCanvasWidthAndHeight.x,
height: createOutcomeCardCanvasWidthAndHeight.y,
}
const [
connection1port,
connection2port,
] = calculateConnectionCoordsByOutcomeCoords(
coordinates[outcomeFormFromActionHash],
allOutcomeDimensions[outcomeFormFromActionHash],
{
x: outcomeFormLeftConnectionX,
y: outcomeFormTopConnectionY,
},
{ width: newOutcomeWidth, height: newOutcomeHeight },
sourceCoordinates,
sourceDimensions,
destinationCoordinates,
destinationDimensions,
outcomeFormRelation
)

drawConnection({
connection1port,
connection2port,
Expand Down
6 changes: 4 additions & 2 deletions web/src/drawing/graphCoordinates.ts
Original file line number Diff line number Diff line change
Expand Up @@ -89,9 +89,9 @@ export default function layoutForGraph(
.nodeSize((node: any) => {
// width and height, plus some extra padding
const width =
node === undefined ? 0 : allOutcomeDimensions[node.data.id].width + 200
node === undefined || allOutcomeDimensions[node.data.id] === undefined ? 0 : allOutcomeDimensions[node.data.id].width + 200
const height =
node === undefined ? 0 : allOutcomeDimensions[node.data.id].height + 200
node === undefined || allOutcomeDimensions[node.data.id] === undefined ? 0 : allOutcomeDimensions[node.data.id].height + 200

return [width, height]
})
Expand All @@ -102,6 +102,8 @@ export default function layoutForGraph(
// define the coordinates of each node
const coordinates = {}
for (const node of dag) {
const dimensions = allOutcomeDimensions[node.data.id]
if (dimensions === undefined) continue
const width = allOutcomeDimensions[node.data.id].width
const height = allOutcomeDimensions[node.data.id].height
coordinates[node.data.id] = {
Expand Down
3 changes: 1 addition & 2 deletions web/src/drawing/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -178,10 +178,9 @@ export default function render(
ctx,
coordinates,
allOutcomeDimensions,
projectTags,
zoomLevel,
translate,
outcomeFormMaybeLinkedOutcome,
outcomeFormContent,
outcomeFormLeftConnectionX,
outcomeFormTopConnectionY,
})
Expand Down
36 changes: 9 additions & 27 deletions web/src/hooks/useContainWithinScreen.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,33 +32,15 @@ export default function useContainWithinScreen({
return
}
// if both x and y are off the screen, move the item up and left
if (
cursorCoordinate.y + itemHeight > window.innerHeight &&
cursorCoordinate.x + itemWidth > window.innerWidth
) {
setInitialized(true)
setRenderCoordinate({
x: cursorCoordinate.x - itemWidth,
y: cursorCoordinate.y - itemHeight,
})
}
// if the item will go off the screen at the bottom edge, move it up so that it is fully visible
else if (cursorCoordinate.y + itemHeight > window.innerHeight) {
setInitialized(true)
setRenderCoordinate({
x: cursorCoordinate.x,
y: cursorCoordinate.y - itemHeight,
})
// if the item will go off the screen at the right edge, move it left so that it is fully visible
} else if (cursorCoordinate.x + itemWidth > window.innerWidth) {
setInitialized(true)
setRenderCoordinate({
x: cursorCoordinate.x - itemWidth,
y: cursorCoordinate.y,
})
} else {
setInitialized(true)
}
setInitialized(true)
// the amount that it (maybe) exceeds the screen width
const overflowX = window.innerWidth - (cursorCoordinate.x + itemWidth)
// the amount that it (maybe) exceeds the screen height
const overflowY = window.innerHeight - (cursorCoordinate.y + itemHeight)
setRenderCoordinate({
x: cursorCoordinate.x + Math.min(overflowX, 0),
y: cursorCoordinate.y + Math.min(overflowY, 0),
})
}, [itemWidth, itemHeight, cursorCoordinate.x, cursorCoordinate.y])

return {
Expand Down

0 comments on commit 69f97e7

Please sign in to comment.