2022-08-01 18:13:02 -07:00
|
|
|
import { QueryClientProvider } from '@tanstack/react-query';
|
2023-10-07 16:39:37 -07:00
|
|
|
import React from 'react';
|
2024-10-10 07:18:20 -07:00
|
|
|
import { HelmetProvider } from 'react-helmet-async';
|
2022-04-21 10:19:33 -07:00
|
|
|
import { Provider } from 'react-redux';
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2024-08-28 04:41:08 -07:00
|
|
|
import { StatProvider } from 'pl-fe/contexts/stat-context';
|
|
|
|
import { createGlobals } from 'pl-fe/globals';
|
|
|
|
import { queryClient } from 'pl-fe/queries/client';
|
2022-01-10 14:25:06 -08:00
|
|
|
|
2023-10-07 16:45:32 -07:00
|
|
|
import { checkOnboardingStatus } from '../actions/onboarding';
|
|
|
|
import { preload } from '../actions/preload';
|
2022-03-14 16:01:09 -07:00
|
|
|
import { store } from '../store';
|
2020-03-27 13:59:38 -07:00
|
|
|
|
2024-08-28 04:41:08 -07:00
|
|
|
import PlFeHead from './pl-fe-head';
|
|
|
|
import PlFeLoad from './pl-fe-load';
|
|
|
|
import PlFeMount from './pl-fe-mount';
|
2023-10-07 16:37:19 -07:00
|
|
|
|
2023-10-07 16:45:32 -07:00
|
|
|
// Configure global functions for developers
|
|
|
|
createGlobals(store);
|
|
|
|
|
|
|
|
// Preload happens synchronously
|
|
|
|
store.dispatch(preload() as any);
|
|
|
|
|
|
|
|
// This happens synchronously
|
|
|
|
store.dispatch(checkOnboardingStatus() as any);
|
|
|
|
|
2022-05-20 10:30:29 -07:00
|
|
|
/** The root React node of the application. */
|
2024-08-28 04:41:08 -07:00
|
|
|
const PlFe: React.FC = () => (
|
2024-05-12 16:18:04 -07:00
|
|
|
<Provider store={store}>
|
|
|
|
<QueryClientProvider client={queryClient}>
|
|
|
|
<StatProvider>
|
2024-10-10 07:18:20 -07:00
|
|
|
<HelmetProvider>
|
2024-10-20 04:20:31 -07:00
|
|
|
<PlFeHead />
|
|
|
|
<PlFeLoad>
|
|
|
|
<PlFeMount />
|
|
|
|
</PlFeLoad>
|
2024-10-10 07:18:20 -07:00
|
|
|
</HelmetProvider>
|
2024-05-12 16:18:04 -07:00
|
|
|
</StatProvider>
|
|
|
|
</QueryClientProvider>
|
|
|
|
</Provider>
|
|
|
|
);
|
2020-03-27 13:59:38 -07:00
|
|
|
|
2024-08-28 04:41:08 -07:00
|
|
|
export { PlFe as default };
|