import * as Sentry from '@sentry/node' import React, { useEffect, useRef } from 'react' import { ErrorBoundary } from 'react-error-boundary' import state, { useSelector } from 'state' import styled from 'styles' import useCamera from 'hooks/useCamera' import useCanvasEvents from 'hooks/useCanvasEvents' import useZoomEvents from 'hooks/useZoomEvents' import Bounds from './bounds/bounding-box' import BoundsBg from './bounds/bounds-bg' import Handles from './bounds/handles' import ContextMenu from './context-menu/context-menu' import Coop from './coop/coop' import Brush from './brush' import Defs from './defs' import Page from './page' import useSafariFocusOutFix from 'hooks/useSafariFocusOutFix' function resetError() { null } export default function Canvas(): JSX.Element { const rCanvas = useRef(null) const rGroup = useRef(null) useCamera(rGroup) useZoomEvents() useSafariFocusOutFix() const events = useCanvasEvents(rCanvas) const isSettingCamera = useSelector((s) => s.isIn('settingCamera')) const isReady = useSelector((s) => s.isIn('ready')) useEffect(() => { if (isSettingCamera) { state.send('MOUNTED_SHAPES') } }, [isSettingCamera]) return ( ) } const MainSVG = styled('svg', { position: 'fixed', overflow: 'hidden', top: 0, left: 0, width: '100%', height: '100%', touchAction: 'none', zIndex: 100, pointerEvents: 'all', backgroundColor: '$canvas', borderTop: '1px solid $border', borderBottom: '1px solid $border', '& *': { userSelect: 'none', }, }) function ErrorFallback({ error, resetErrorBoundary }) { React.useEffect(() => { const copy = 'Sorry, something went wrong. Press Ok to reset the document, or press cancel to continue and see if it resolves itself.' console.error(error) Sentry.captureException(error) if (window.confirm(copy)) { state.send('RESET_DOCUMENT_STATE') resetErrorBoundary() } }, []) return }