import { getShapeStyle } from 'state/shape-styles' import { getShapeUtils } from 'state/shape-utils' import React, { memo } from 'react' import { useSelector } from 'state' import { deepCompareArrays, getCurrentCamera, getPage } from 'utils/utils' import { DotCircle, Handle } from './misc' export default function Defs(): JSX.Element { const zoom = useSelector((s) => getCurrentCamera(s.data).zoom) const currentPageShapeIds = useSelector(({ data }) => { return Object.values(getPage(data).shapes) .filter(Boolean) .filter((shape) => !getShapeUtils(shape).isForeignObject) .sort((a, b) => a.childIndex - b.childIndex) .map((shape) => shape.id) }, deepCompareArrays) return ( {currentPageShapeIds.map((id) => ( ))} ) } const Def = memo(function Def({ id }: { id: string }) { const shape = useSelector((s) => getPage(s.data).shapes[id]) if (!shape) return null const style = getShapeStyle(shape.style) return React.cloneElement( getShapeUtils(shape).render(shape, { isEditing: false }), { id, ...style } ) })