Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

selected.tsx 1.8KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. import styled from 'styles'
  2. import { useSelector } from 'state'
  3. import {
  4. deepCompareArrays,
  5. getBoundsCenter,
  6. getPage,
  7. getSelectedIds,
  8. setToArray,
  9. } from 'utils/utils'
  10. import { getShapeUtils } from 'lib/shape-utils'
  11. import useShapeEvents from 'hooks/useShapeEvents'
  12. import { memo, useRef } from 'react'
  13. import { ShapeType } from 'types'
  14. import * as vec from 'utils/vec'
  15. export default function Selected() {
  16. const currentSelectedShapeIds = useSelector(
  17. ({ data }) => setToArray(getSelectedIds(data)),
  18. deepCompareArrays
  19. )
  20. const isSelecting = useSelector((s) => s.isIn('selecting'))
  21. if (!isSelecting) return null
  22. return (
  23. <g>
  24. {currentSelectedShapeIds.map((id) => (
  25. <ShapeOutline key={id} id={id} />
  26. ))}
  27. </g>
  28. )
  29. }
  30. export const ShapeOutline = memo(function ShapeOutline({ id }: { id: string }) {
  31. const rIndicator = useRef<SVGUseElement>(null)
  32. const shape = useSelector((s) => getPage(s.data).shapes[id])
  33. const events = useShapeEvents(id, shape?.type === ShapeType.Group, rIndicator)
  34. if (!shape) return null
  35. // This needs computation from state, similar to bounds, in order
  36. // to handle parent rotation.
  37. const center = getShapeUtils(shape).getCenter(shape)
  38. const transform = `
  39. rotate(${shape.rotation * (180 / Math.PI)}, ${center})
  40. translate(${shape.point})
  41. `
  42. return (
  43. <SelectIndicator
  44. ref={rIndicator}
  45. as="use"
  46. href={'#' + id}
  47. transform={transform}
  48. isLocked={shape.isLocked}
  49. {...events}
  50. />
  51. )
  52. })
  53. const SelectIndicator = styled('path', {
  54. zStrokeWidth: 2,
  55. strokeLineCap: 'round',
  56. strokeLinejoin: 'round',
  57. stroke: '$selected',
  58. pointerEvents: 'none',
  59. variants: {
  60. isLocked: {
  61. true: {
  62. zDash: 2,
  63. },
  64. false: {},
  65. },
  66. variant: {},
  67. },
  68. })