您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

shape-group.tsx 792B

12345678910111213141516171819202122232425262728293031323334353637
  1. import React from "react"
  2. import state from "state"
  3. import { Shape } from "types"
  4. import { getPointerEventInfo } from "utils/utils"
  5. export default function ShapeGroup({
  6. id,
  7. children,
  8. }: {
  9. id: string
  10. children: React.ReactNode
  11. }) {
  12. return (
  13. <g
  14. onPointerDown={(e) =>
  15. state.send("POINTED_SHAPE", { id, ...getPointerEventInfo(e) })
  16. }
  17. onPointerUp={(e) =>
  18. state.send("STOPPED_POINTING_SHAPE", {
  19. id,
  20. ...getPointerEventInfo(e),
  21. })
  22. }
  23. onPointerEnter={(e) =>
  24. state.send("HOVERED_SHAPE", { id, ...getPointerEventInfo(e) })
  25. }
  26. onPointerLeave={(e) =>
  27. state.send("UNHOVERED_SHAPE", {
  28. id,
  29. ...getPointerEventInfo(e),
  30. })
  31. }
  32. >
  33. {children}
  34. </g>
  35. )
  36. }