Skip to content

Commit

Permalink
feat: get tooptip back
Browse files Browse the repository at this point in the history
  • Loading branch information
Rassl committed Dec 25, 2024
1 parent 66d2570 commit b75f5e6
Show file tree
Hide file tree
Showing 3 changed files with 49 additions and 34 deletions.
2 changes: 1 addition & 1 deletion src/components/App/SideBar/Relevance/Episode/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ export const Episode = ({
node,
}: Props) => {
const searchTerm = useAppStore((s) => s.currentSearch)
const { setHoveredNode } = useGraphStore((s) => s)
const setHoveredNode = useGraphStore((s) => s.setHoveredNode)
const text = highlightSearchTerm(String(newText), searchTerm) as string
const name = highlightSearchTerm(String(newName), searchTerm) as string
const subtitleSource = type === 'show' ? '' : showTitle
Expand Down
40 changes: 27 additions & 13 deletions src/components/Universe/CursorTooltip/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,46 +13,59 @@ export const CursorTooltip = () => {
if (tooltipRef.current) {
tooltipRef.current.style.display = node ? 'block' : 'none'
}
}, [node, tooltipRef])
}, [node])

useEffect(() => {
let animationFrameId: number

const handleMouseMove = (e: MouseEvent) => {
const tooltip = tooltipRef.current

if (!tooltip) {
return
}

tooltip.style.top = `${e.clientY + 10}px`
tooltip.style.left = `${e.clientX + 10}px`
// Hide tooltip if not hovering over canvas
const target = e.target as Element

if (target.tagName !== 'CANVAS') {
tooltip.style.display = 'none'

return
}

tooltip.style.display = 'block' // Ensure tooltip is visible if hovering canvas

// Prevent clipping at screen edges
const tooltipWidth = tooltip.offsetWidth
const tooltipHeight = tooltip.offsetHeight
const maxX = window.innerWidth - tooltipWidth - 10
const maxY = window.innerHeight - tooltipHeight - 10

if (e.clientX + 10 + tooltipWidth > window.innerWidth) {
tooltip.style.left = `${maxX}px`
}
const x = Math.min(e.clientX + 10, maxX)
const y = Math.min(e.clientY + 10, maxY)

if (e.clientY + 10 + tooltipHeight > window.innerHeight) {
tooltip.style.top = `${maxY}px`
}
animationFrameId = requestAnimationFrame(() => {
tooltip.style.transform = `translate(${x}px, ${y}px)`
})
}

window.addEventListener('mousemove', handleMouseMove)

return () => {
window.removeEventListener('mousemove', handleMouseMove)
cancelAnimationFrame(animationFrameId)
}
}, []) // Empty array ensures the listener is added only once
}, [])

return <TooltipContainer ref={tooltipRef}>{node && <HoverCard node={node} />}</TooltipContainer>
}

const TooltipContainer = styled(Flex)`
position: fixed;
position: fixed; /* Fixed position for the tooltip */
left: 0;
top: 0;
transform: translate(0, 0); /* Initial transform */
will-change: transform; /* Optimize for transform changes */
background: ${colors.BG1};
color: white;
padding: 5px;
Expand All @@ -62,5 +75,6 @@ const TooltipContainer = styled(Flex)`
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
display: none; /* Start hidden */
display: none; /* Initially hidden */
box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.2); /* Optional shadow for better visibility */
`
41 changes: 21 additions & 20 deletions src/components/Universe/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import { Flex } from '../common/Flex'
import { outlineEffectColor } from './constants'
import { Controls } from './Controls'
import { initialCameraPosition, selectionGraphCameraPosition } from './Controls/CameraAnimations/constants'
import { CursorTooltip } from './CursorTooltip/index'
import { Graph } from './Graph'
import { Lights } from './Lights'
import { Overlay } from './Overlay'
Expand Down Expand Up @@ -135,26 +136,26 @@ const _Universe = () => {
<Suspense fallback={null}>
<Leva hidden isRoot />

{true && (
<Canvas
camera={cameraProps}
frameloop={selectedNode ? 'demand' : 'always'}
id="universe-canvas"
onCreated={onCreatedHandler}
onWheel={onWheelHandler}
>
{isDevelopment && <Perf position="top-right" style={{ top: '80px' }} />}
<Suspense fallback={<Fallback />}>
<Preload />

<AdaptiveDpr />

<AdaptiveEvents />

<Content />
</Suspense>
</Canvas>
)}
<Canvas
camera={cameraProps}
frameloop={selectedNode ? 'demand' : 'always'}
id="universe-canvas"
onCreated={onCreatedHandler}
onWheel={onWheelHandler}
>
{isDevelopment && <Perf position="top-right" style={{ top: '80px' }} />}
<Suspense fallback={<Fallback />}>
<Preload />

<AdaptiveDpr />

<AdaptiveEvents />

<Content />
</Suspense>
</Canvas>
<CursorTooltip />

{selectedNode ? (
<SelectionWrapper>
<Canvas
Expand Down

0 comments on commit b75f5e6

Please sign in to comment.