import './polyfill/dispose'; import '@affine/core/bootstrap/preload'; import { appConfigProxy } from '@affine/core/hooks/use-app-config-storage'; import { performanceLogger } from '@affine/core/shared'; import { apis, events } from '@affine/electron-api'; import { init, reactRouterV6BrowserTracingIntegration, setTags, } from '@sentry/react'; import { debounce } from 'lodash-es'; import { StrictMode, useEffect } from 'react'; import { createRoot } from 'react-dom/client'; import { createRoutesFromChildren, matchRoutes, useLocation, useNavigationType, } from 'react-router-dom'; import { App } from './app'; const performanceMainLogger = performanceLogger.namespace('main'); function main() { performanceMainLogger.info('start'); // load persistent config for electron // TODO(@Peng): should be sync, but it's not necessary for now appConfigProxy .getSync() .catch(() => console.error('failed to load app config')); // skip bootstrap setup for desktop onboarding if (window.appInfo?.windowName === 'onboarding') { performanceMainLogger.info('skip setup'); } else { performanceMainLogger.info('setup start'); if (window.SENTRY_RELEASE || environment.isDebug) { // https://docs.sentry.io/platforms/javascript/guides/electron/ init({ dsn: process.env.SENTRY_DSN, environment: process.env.BUILD_TYPE ?? 'development', integrations: [ reactRouterV6BrowserTracingIntegration({ useEffect, useLocation, useNavigationType, createRoutesFromChildren, matchRoutes, }), ], }); setTags({ appVersion: runtimeConfig.appVersion, editorVersion: runtimeConfig.editorVersion, }); window.addEventListener('offline', () => { apis?.ui.handleNetworkChange(false); }); window.addEventListener('online', () => { apis?.ui.handleNetworkChange(true); }); } const handleMaximized = (maximized: boolean | undefined) => { document.documentElement.dataset.maximized = String(maximized); }; const handleFullscreen = (fullscreen: boolean | undefined) => { document.documentElement.dataset.fullscreen = String(fullscreen); }; apis?.ui.isMaximized().then(handleMaximized).catch(console.error); apis?.ui.isFullScreen().then(handleFullscreen).catch(console.error); events?.ui.onMaximized(handleMaximized); events?.ui.onFullScreen(handleFullscreen); const handleResize = debounce(() => { apis?.ui.handleWindowResize().catch(console.error); }, 50); window.addEventListener('resize', handleResize); performanceMainLogger.info('setup done'); } mountApp(); } function mountApp() { performanceMainLogger.info('import app'); // eslint-disable-next-line @typescript-eslint/no-non-null-assertion const root = document.getElementById('app')!; performanceMainLogger.info('render app'); createRoot(root).render( ); } try { main(); } catch (err) { console.error('Failed to bootstrap app', err); }