2022-05-11 23:32:58 +00:00
|
|
|
import '@fontsource/inter/variable.css';
|
2022-10-25 01:41:46 +00:00
|
|
|
import { LibraryContextProvider, queryClient, useDebugState } from '@sd/client';
|
2023-01-20 03:23:22 +00:00
|
|
|
import { Dialogs } from '@sd/ui';
|
2022-11-01 13:32:56 +00:00
|
|
|
import {
|
|
|
|
Dedupe as DedupeIntegration,
|
|
|
|
HttpContext as HttpContextIntegration,
|
|
|
|
init
|
|
|
|
} from '@sentry/browser';
|
2022-08-12 06:48:49 +00:00
|
|
|
import { QueryClientProvider, defaultContext } from '@tanstack/react-query';
|
2022-08-03 15:36:03 +00:00
|
|
|
import { ReactQueryDevtools } from '@tanstack/react-query-devtools';
|
2022-10-01 17:37:35 +00:00
|
|
|
import dayjs from 'dayjs';
|
|
|
|
import advancedFormat from 'dayjs/plugin/advancedFormat';
|
|
|
|
import duration from 'dayjs/plugin/duration';
|
|
|
|
import relativeTime from 'dayjs/plugin/relativeTime';
|
2022-06-18 08:35:51 +00:00
|
|
|
import { ErrorBoundary } from 'react-error-boundary';
|
2022-09-12 15:33:16 +00:00
|
|
|
import { MemoryRouter, useNavigate } from 'react-router-dom';
|
2022-05-23 09:47:24 +00:00
|
|
|
|
2022-06-18 08:35:51 +00:00
|
|
|
import { AppRouter } from './AppRouter';
|
|
|
|
import { ErrorFallback } from './ErrorFallback';
|
2022-05-11 23:32:58 +00:00
|
|
|
import './style.scss';
|
2022-04-27 01:14:39 +00:00
|
|
|
|
2022-10-01 17:37:35 +00:00
|
|
|
dayjs.extend(advancedFormat);
|
|
|
|
dayjs.extend(relativeTime);
|
|
|
|
dayjs.extend(duration);
|
|
|
|
|
2022-10-29 09:06:09 +00:00
|
|
|
init({
|
2022-11-01 13:32:56 +00:00
|
|
|
dsn: 'https://2fb2450aabb9401b92f379b111402dbc@o1261130.ingest.sentry.io/4504053670412288',
|
|
|
|
environment: import.meta.env.MODE,
|
|
|
|
defaultIntegrations: false,
|
|
|
|
integrations: [new HttpContextIntegration(), new DedupeIntegration()]
|
2022-10-29 09:06:09 +00:00
|
|
|
});
|
|
|
|
|
2022-09-08 22:29:47 +00:00
|
|
|
export default function SpacedriveInterface() {
|
2022-05-23 07:54:46 +00:00
|
|
|
return (
|
2022-08-11 09:35:27 +00:00
|
|
|
<ErrorBoundary FallbackComponent={ErrorFallback}>
|
2022-08-12 06:48:49 +00:00
|
|
|
<QueryClientProvider client={queryClient} contextSharing={true}>
|
2022-10-25 01:41:46 +00:00
|
|
|
<Devtools />
|
2022-09-08 22:29:47 +00:00
|
|
|
<MemoryRouter>
|
2022-09-12 15:33:16 +00:00
|
|
|
<AppRouterWrapper />
|
2022-09-08 22:29:47 +00:00
|
|
|
</MemoryRouter>
|
2022-08-03 15:36:03 +00:00
|
|
|
</QueryClientProvider>
|
|
|
|
</ErrorBoundary>
|
2022-05-23 07:54:46 +00:00
|
|
|
);
|
2022-04-17 18:44:34 +00:00
|
|
|
}
|
2022-09-12 15:33:16 +00:00
|
|
|
|
2022-10-25 01:41:46 +00:00
|
|
|
function Devtools() {
|
|
|
|
const debugState = useDebugState();
|
|
|
|
|
|
|
|
// The `context={defaultContext}` part is required for this to work on Windows. Why, idk, don't question it
|
|
|
|
return debugState.reactQueryDevtools !== 'disabled' ? (
|
|
|
|
<ReactQueryDevtools
|
|
|
|
position="bottom-right"
|
|
|
|
context={defaultContext}
|
|
|
|
toggleButtonProps={{
|
|
|
|
className: debugState.reactQueryDevtools === 'invisible' ? 'opacity-0' : ''
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
) : null;
|
|
|
|
}
|
|
|
|
|
2022-09-12 15:33:16 +00:00
|
|
|
// This can't go in `<SpacedriveInterface />` cause it needs the router context but it can't go in `<AppRouter />` because that requires this context
|
|
|
|
function AppRouterWrapper() {
|
|
|
|
const navigate = useNavigate();
|
|
|
|
|
|
|
|
return (
|
|
|
|
<LibraryContextProvider onNoLibrary={() => navigate('/onboarding')}>
|
|
|
|
<AppRouter />
|
2023-01-20 03:23:22 +00:00
|
|
|
<Dialogs />
|
2022-09-12 15:33:16 +00:00
|
|
|
</LibraryContextProvider>
|
|
|
|
);
|
|
|
|
}
|