import { OverlayProvider } from '@react-aria/overlays' import { ErrorBoundary } from '@sentry/react' import { ThemeColorsProvider } from 'Components/utils/colors' import { DisableAnimationOnPrintProvider } from 'Components/utils/DisableAnimationContext' import { IsEmbeddedProvider } from 'Components/utils/embeddedContext' import { SitePathProvider, SitePaths } from 'Components/utils/SitePathsContext' import { GlobalStyle } from 'DesignSystem/global-style' import { Container } from 'DesignSystem/layout' import DesignSystemThemeProvider from 'DesignSystem/root' import { H1 } from 'DesignSystem/typography/heading' import { Link } from 'DesignSystem/typography/link' import { Body, Intro } from 'DesignSystem/typography/paragraphs' import { createBrowserHistory } from 'history' import i18next from 'i18next' import logo from 'Images/logo-monentreprise.svg' import { useIframeResizer } from 'Hooks/useIframeResizer' import { createContext, ReactNode, useMemo } from 'react' import { HelmetProvider } from 'react-helmet-async' import { I18nextProvider } from 'react-i18next' import { Provider as ReduxProvider } from 'react-redux' import { Router } from 'react-router-dom' import reducers, { RootState } from 'Reducers/rootReducer' import { composeWithDevToolsDevelopmentOnly } from '@redux-devtools/extension' import { applyMiddleware, createStore, Middleware, PreloadedState, Store, } from 'redux' // ATInternet Tracking import { TrackingContext } from './ATInternetTracking' import { createTracker } from './ATInternetTracking/Tracker' import * as safeLocalStorage from './storage/safeLocalStorage' import { inIframe } from './utils' if ( !import.meta.env.SSR && import.meta.env.MODE === 'production' && 'serviceWorker' in navigator && !inIframe() ) { window.addEventListener('load', () => { navigator.serviceWorker .register('/sw.js') .then((registration) => { // eslint-disable-next-line no-console console.log('SW registered: ', registration) }) .catch((registrationError) => { // eslint-disable-next-line no-console console.log('SW registration failed: ', registrationError) }) }) } type SiteName = 'mon-entreprise' | 'infrance' | 'publicodes' export const SiteNameContext = createContext(null) const composeEnhancers = composeWithDevToolsDevelopmentOnly( import.meta.env.VITE_REDUX_TRACE ? { trace: true, traceLimit: 25 } : {} ) export type ProviderProps = { basename: SiteName children: ReactNode sitePaths?: SitePaths initialStore?: PreloadedState onStoreCreated?: (store: Store) => void reduxMiddlewares?: Array } export default function Provider({ basename, reduxMiddlewares = [], initialStore, onStoreCreated, children, sitePaths = {} as SitePaths, }: ProviderProps): JSX.Element { const storeEnhancer = composeEnhancers(applyMiddleware(...reduxMiddlewares)) // Hack: useMemo is used to persist the store across hot reloads. const store = useMemo(() => { return createStore(reducers, initialStore, storeEnhancer) }, []) onStoreCreated?.(store) useIframeResizer() return ( logo service mon-entreprise urssaf

Une erreur est survenue

L'équipe technique mon-entreprise a été automatiquement prévenue. Vous pouvez également nous contacter directement à l'adresse{' '} contact@mon-entreprise.beta.gouv.fr {' '} si vous souhaitez partager une remarque. Veuillez nous excuser pour la gêne occasionnée. } > <>{children}
) } function BrowserRouterProvider({ children, basename, }: { children: ReactNode basename: string }) { // The server rouer is only provided in the entry-server file if (import.meta.env.SSR) { return <>{children} } // eslint-disable-next-line react-hooks/rules-of-hooks const history = useMemo( () => createBrowserHistory({ basename: import.meta.env.MODE === 'production' ? '' : basename, }), [basename] ) const ATTracker = createTracker( import.meta.env.VITE_AT_INTERNET_SITE_ID, safeLocalStorage.getItem('tracking:do_not_track') === '1' || navigator.doNotTrack === '1' ) return ( <>{children} ) }