| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 | import * as React from 'react'import { observer } from 'mobx-react-lite'import { TLBounds, BoundsUtils, TLOffset } from '@tldraw/core'import { useCounterScaledPosition, useRendererContext } from '~hooks'import type { TLReactShape } from '~lib'const stopEventPropagation = (e: React.PointerEvent) => e.stopPropagation()export interface TLContextBarContainerProps<S extends TLReactShape> {  shapes: S[]  hidden: boolean  bounds: TLBounds  rotation?: number}export const ContextBarContainer = observer(function ContextBarContainer<S extends TLReactShape>({  shapes,  hidden,  bounds,  rotation = 0,}: TLContextBarContainerProps<S>) {  const {    components: { ContextBar },    viewport: {      bounds: vpBounds,      camera: {        point: [x, y],        zoom,      },    },  } = useRendererContext()  const rBounds = React.useRef<HTMLDivElement>(null)  const rotatedBounds = BoundsUtils.getRotatedBounds(bounds, rotation)  const scaledBounds = BoundsUtils.multiplyBounds(rotatedBounds, zoom)  useCounterScaledPosition(rBounds, bounds, rotation, 10003)  if (!ContextBar) throw Error('Expected a ContextBar component.')  const screenBounds = BoundsUtils.translateBounds(scaledBounds, [x * zoom, y * zoom])  const offsets: TLOffset = {    left: screenBounds.minX,    right: vpBounds.width - screenBounds.maxX,    top: screenBounds.minY,    bottom: vpBounds.height - screenBounds.maxY,    width: screenBounds.width,    height: screenBounds.height,  }  const inView =    BoundsUtils.boundsContain(vpBounds, screenBounds) ||    BoundsUtils.boundsCollide(vpBounds, screenBounds)  React.useLayoutEffect(() => {    const elm = rBounds.current    if (!elm) return    if (hidden || !inView) {      elm.classList.add('tl-fade-out')      elm.classList.remove('tl-fade-in')    } else {      elm.classList.add('tl-fade-in')      elm.classList.remove('tl-fade-out')    }  }, [hidden, inView])  return (    <div      ref={rBounds}      className="tl-counter-scaled-positioned tl-fade-out"      aria-label="context-bar-container"      onPointerMove={stopEventPropagation}      onPointerUp={stopEventPropagation}      onPointerDown={stopEventPropagation}    >      <ContextBar        hidden={hidden}        shapes={shapes}        bounds={bounds}        offsets={offsets}        scaledBounds={scaledBounds}        rotation={rotation}      />    </div>  )})
 |